Com o desenvolvimento da tecnologia, a complexidade do desenvolvimento está ficando cada vez maior. O método tradicional de desenvolvimento transforma um sistema em um aplicativo completo. Muitas vezes acontece que uma pequena alteração ou um pequeno aumento de função pode fazer com que a lógica geral mude. Modificações, fazendo com que todo o corpo seja afetado por um único fio de cabelo.
Por meio do desenvolvimento de componentes, o desenvolvimento e a manutenção separados podem ser efetivamente realizados e podem ser combinados à vontade. Melhore consideravelmente a eficiência do desenvolvimento e reduza os custos de manutenção.
Hoje apresentarei um componente que imita o alerta pop-up da caixa de filtro no lado direito do Meituan; o endereço de download do código-fonte está anexado : https://ext.dcloud.net.cn/plugin?id=13602
As renderizações são as seguintes:
[Falha na transferência da imagem do link externo, o site de origem pode ter um mecanismo anti-leeching, é recomendável salvar a imagem e carregá-la diretamente (img-dCgLNhgW-1689509203340)(https://p3-juejin.byteimg.com/tos -cn-i-k3u1fbpfcp /80811c30cb684ed0bbedf7dca0c3337e~tplv-k3u1fbpfcp-zoom-1.image)]
O código de implementação é o seguinte
cc-rightPopup
Instruções
<!-- pop-show:是否显示弹框 color:主题色 classList:分类数组 @sureClick:筛选确认 @hideClick:隐藏事件 -->
<cc-rightPopup :pop-show="popShow" :colors="colors" :classList="classList" @sureClick="sureClick"
@hideClick="hideright"></cc-rightPopup>
// 隐藏处理
hideright() {
this.popShow = false;
},
// 筛选确认
sureClick(paramDict, selArr) {
this.popShow = false;
uni.showModal({
title: '筛选数据',
content: '筛选价格数据 = ' + JSON.stringify(paramDict) + ' 筛选按钮数据= ' + JSON.stringify(selArr)
})
}
Parte de implementação do código HTML
<template>
<view class="content">
<button style="margin: 60px 90px;" @click="showPopClick">点击弹框</button>
<!-- pop-show:是否显示弹框 color:主题色 classList:分类数组 @sureClick:筛选确认 @hideClick:隐藏事件 -->
<cc-rightPopup :pop-show="popShow" :colors="colors" :classList="classList" @sureClick="sureClick"
@hideClick="hideright"></cc-rightPopup>
</view>
</template>
<script>
export default {
data() {
return {
colors: '#fa436a',
popShow: false,
classList: [{
name: '营业事件',
id: 1,
child: [{
name: '0-5时',
id: 2
}, {
name: '5-10时',
id: 3
}, {
name: '10-14时',
id: 2
}, {
name: '14-18时',
id: 3
}, {
name: '18-22时',
id: 2
}, {
name: '22-24时',
id: 3
}]
}, {
name: '用餐人数',
id: 2,
child: [{
name: '单人餐',
id: 1
}, {
name: '双人餐',
id: 2
}, {
name: '3-4人餐',
id: 2
},
{
name: '5-10人餐',
id: 2
}
]
}],
}
},
methods: {
showPopClick() {
this.popShow = true;
},
hideright() {
this.popShow = false;
},
sureClick(paramDict, selArr) {
this.popShow = false;
uni.showModal({
title: '筛选数据',
content: '筛选价格数据 = ' + JSON.stringify(paramDict) + ' 筛选按钮数据= ' + JSON.stringify(selArr)
})
}
}
}
</script>
<style>
page {
background-color: #f2f2f2;
margin-bottom: 50px;
}
</style>