打开WX开发者工具,不使用模板

效果展示

一、创建页面

在app.json配置lv-list页面、和lv-like页面,header头部组件、menu喜欢的包包组件

二、在lv-list下创建.js文件手写数据

// CommonJS模块语法
module.exports = [{id: '001',img: 'https://secure.louisvuitton.cn/images/is/image/lv/1/PP_VP_AS/%E8%B7%AF%E6%98%93%E5%A8%81%E7%99%BB--M20761_PM2_Front%20view.jpg?wid=555&hei=555',name: 'RED 挎包',price: '13566'
}, {id: '002',img: 'https://secure.louisvuitton.cn/images/is/image/lv/1/PP_VP_AS/%E8%B7%AF%E6%98%93%E5%A8%81%E7%99%BB--M20379_PM2_Front%20view.jpg?wid=555&hei=555',name: 'BLUE 挎包',price: '16566'
}, {id: '003',img: 'https://secure.louisvuitton.cn/images/is/image/lv/1/PP_VP_AS/%E8%B7%AF%E6%98%93%E5%A8%81%E7%99%BB--M20379_PM2_Front%20view.jpg?wid=555&hei=555',name: 'WHITE 挎包',price: '24566'
}];

三、封装头部组件

wxml页面

<!-- header组件wxml页面 -->
<view class="header"><button class="btn nav"></button><button class="btn" data-type="like" bindtap="go"></button><view class="logo"  data-type="list" bindtap="go"></view><button class="btn"></button><button class="btn"></button>
</view>

wxss页面

.header {display: flex;justify-content: space-between;height: 100rpx;padding: 0 27rpx;border-bottom: 3rpx solid #e3e2dd;
}
.header .btn {width: 72rpx;height: 100%;padding: 0;background-repeat: no-repeat;background-position: center;background-size: 45.3rpx;
}
.header .nav {background-image: url();
}
.header .like {background-image: url();
}
.header .user {background-image: url();
}
.header .cart {background-image: url();
}
.header .logo {flex: auto;background: url() no-repeat center center / 210rpx;
}.header .tag {width: 23rpx;line-height: 23rpx;margin: 25rpx 0 0 50rpx;border-radius: 50%;background: #372d24;color: #fff;text-align: center;font-size: 14rpx;overflow: hidden;
}

 .js结构

// 页面用Page方法定义,组件用Component定义
// 组件需要在json文件中设置"component": true
Component({// 组件的自定义属性,外部传入的properties: {count: {type: Number, // 数据类型 String、Boolean、Object、Arrayvalue: 0 // 默认值}},// 组件的内部数据,内部自己使用data: {},// 组件的方法列表methods: {go(event) {// getCurrentPages方法获取所有页面栈,相当于历史记录const pages = getCurrentPages();// 页面栈中最后的元素是最新的/当前的页面,navigateTo访问新页面会入栈相当于push,返回旧页面会出栈相当于popconst currentPage = pages[pages.length - 1];// 获取当前页面的路径const { route } = currentPage;// 收藏按钮有子元素,target可能是子元素const { type } = event.currentTarget.dataset;// 判断要跳转的路径是当前页面,就不跳了if (route.includes(type)) return;wx.navigateTo({url: `/pages/lv-${type}/lv-${type}`});}}
})

 分别在list和like页面.json中引入组件

  "usingComponents": {"header":"/components/header/header","menu":"/components/menu/menu"}

四、lv-list 页面

1、标题

lv-list wxml页面
<!-- 所有包标题 -->
<view class="title"><view class="name">所有包款</view><view class="filter" bindtap="showMenu">显示筛选器</view>
</view>.js结构
showMenu(){console.log('showMenu');this.setData({show: true})
},

2、包包列表 

wxml页面
<wxs module="wxs">
function some(arr,id){return arr.some(function(i){return i.id === id})
}
module.exports={some:some
}
</wxs>
<!-- 包包列表 -->
<view class="list"><view class="item" wx:for="{{list}}" wx:key="id"><image src="{{item.img}}" mode="aspectFit"></image><view class="name">{{item.name}}</view><view class="price">{{item.price}}</view><buttonclass="{{wxs.some(likeList,item.id ) ? 'checked':''}}"data-id="{{item.id}}"bindtap="toggle"></button></view>
</view>
.js结构const list = require('./list.js')//导入数据data:{list,//挂载到页面上likeList:[], //存放当前下标
},
// onLoad在navigateBack回来时不会执行,返回来时只执行onShow
// 本页面通过navigateTo跳转到别的页面时,本页面不会销毁/不执行onUnload,只执行onHide
onShow(){wx.getStorage({ //从本地缓存中异步获取指定 key 的内容key:'like-list',success:({data}) =>{this.setData({likeList:data })console.log(data);}})
},
toggle({target}){const  {id}  = target.dataset //获取当前事件的idconst index = this.data.likeList.findIndex(i => i.id === id)//判断likeList中有没有,有就删,没有就把list的下标添加到likeListif(index === -1){this.data.likeList.push(this.data.list.find(i => i.id === id))}else{this.data.likeList.splice(index,1)}this.setData({likeList:this.data.likeList //把新的下标赋值到定义的字段中})wx.setStorageSync('like-list',this.data.likeList) //将数据存储在本地缓存中指定的 key 中
},

五、lv-like 页面

wxml页面 可以直接把list页面的包包结构拿过来使用 更新data数据中定义的字段即可likeList
注意添加新的删除事件
<header count="{{likeList.length}}"/><view class="list"><view class="item" wx:for="{{likeList}}" wx:key="id"><image src="{{item.img}}"></image><view class="name">{{item.name}}</view><view class="price">{{item.price}}</view><!-- data-index="{{index}}"绑定当前 --><buttondata-index="{{index}}"bindtap="del">×</button></view>
</view>
.js结构
Page({data:{ likeList:[]},onShow(){//监听页面显示//this指向问题,1.把外面的this定义成变量使用const self = this;wx.getStorage({key:'like-list',success({data}){self.setData({likeList:data})}});},//弹框是否删除del({target:{dataset:{index}}}){wx.showModal({title: '将此内容从您的愿望录中移除',content:'请确认是否将此内容从您的愿望录中移除取',confirmText:'删除',success:({confirm})=>{ //confirm 为 true 时,表示用户点击了确定按钮if(!confirm) return // 点击取消false就returnthis.data.likeList.splice(index,1) //否则就删除当前下标的数据this.setData({likeList:this.data.likeList // 更新当前数据状态});wx.setStorageSync('like-list', this.data.likeList)// wx.setStorageSync将数据存储在本地缓存中指定的 key 中。//会覆盖掉原来该 key 对应的内容。//除非用户主动删除或因存储空间原因被系统清理,否则数据都一直可用。},})}
})

六、右侧筛选器

lv-list页面

<!-- 右侧筛选器 -->
wxml 页面
<menu show="{{show}}"bind:close = "closeMenu"bind:filter = "filter"
/>
.js 结构
// 右侧筛选器
closeMenu(){ //初始为falseconsole.log('closeMenu');this.setData({show:false})
},
filter({detail}){console.log(Object.values(detail).flat().filter(i => i.checked).map(i => i.label));
}

menu 组件中

wxml页面
<wxs module="seec">
function checkedLength(arr) {return arr.filter(function(i) {return i.checked;}).length;
}
module.exports = {checkedLength: checkedLength
};
</wxs><page-containershow="{{show}}"position="right"bind:afterleave="close"
><view class="top"><view class="title">显示筛选器<block wx:if="{{seec.checkedLength(formData.category) + seec.checkedLength(formData.color) > 0}}">({{seec.checkedLength(formData.category) + seec.checkedLength(formData.color)}})</block></view><view class="reset">重置所有筛选</view><button bindtap="close">X</button></view><view class="category-list"><view class="title">目录<block wx:if="{{seec.checkedLength(formData.category) > 0}}">({{seec.checkedLength(formData.category)}})</block></view><viewclass="category-item"wx:for="{{formData.category}}"wx:key="label"data-index="{{index}}"data-type="category"bindtap="toggle"><view class="checkbox{{item.checked ? ' checked' : ''}}"></view><text>{{item.label}}</text></view></view><view class="color-list"><view class="title">颜色<block wx:if="{{seec.checkedLength(formData.color) > 0}}">({{seec.checkedLength(formData.color)}})</block></view><viewclass="color-item"wx:for="{{formData.color}}"wx:key="label"style="border: 1px solid {{item.checked ? '#000' : '#ccc'}}"data-index="{{index}}"data-type="color"bindtap="toggle"><image class="img" src="{{item.img}}" mode="aspectFill" /><text>{{item.label}}</text></view></view>菜单内容
</page-container>
// components/menu/menu.js
Component({properties:{show:{type:Boolean,value:false}},data:{formData:{category: [{label: '斜跨包',checked: false}, {label: '手提包',checked: false}],color: [{label: '橙色',img: 'https://www.louisvuitton.cn/images/is/image/MAC-Z10_orange?wid=216&hei=216',checked: false},{label: '蓝色',img: 'https://www.louisvuitton.cn/images/is/image/MAC-Z04_bleu?wid=216&hei=216',checked: false}]}},methods:{close(){// 组件内部不允许修改properties// 子组件给父组件传值// triggerEvent派发/触发/发送/给/送出去 一个自定义事件this.triggerEvent('close');},toggle({ currentTarget }){const { index, type }= currentTarget.dataset;this.data.formData[type][index].checked = !this.data.formData[type][index].checked;this.setData({formData: this.data.formData});this.triggerEvent('filter', this.data.formData);//setData应只传发生变化的数据,减少数据通信量,小程序逻辑层和视图层分开//https://developers.weixin.qq.com/miniprogram/dev/framework/performance/tips/runtime_setData.html// this.setData({//   [`formData.${type}[${index}].checked`]: this.data.formData[type][index].checked// });}}
})
.top {display: flex;
}.category-list, .color-list {margin: 50rpx 30rpx;border-top: 1px solid #333;
}
.color-list {display: flex;flex-wrap: wrap;
}
.color-item {width: 150rpx;height: 250rpx;margin: 10rpx;padding: 10rpx;
}
.color-item .img {width: 130rpx;height: 130rpx;
}.category-list .checkbox {position: relative;width: 50rpx;height: 50rpx;margin-right: 10rpx;border: 5rpx solid #333;
}
.category-list .checkbox.checked:after {content: "";position: absolute;width: 30rpx;height: 20rpx;border-left: 5rpx solid #333;border-bottom: 5rpx solid #333;transform: rotate(-40deg) translate(5rpx, 5rpx);
}
.category-item {display: flex;padding: 5rpx 0;
}

微信LV项目(全流程)相关推荐

  1. 项目开发流程_视频网课:房地产开发项目全流程全税种税收筹划

    致CFO:今天不税筹,明天就愁税 为了支持企业发展,国家出台了诸多税收优惠政策.但因不同行业税种多样,如房地产业涉税就有20余种,如何做到用好优惠政策,优化缴税结构?避免重复纳税,降低财务成本,还要合 ...

  2. pythonmysql部署_详解centos7+django+python3+mysql+阿里云部署项目全流程

    (PS:本文假设你已经在本地联调好django和客户端,只是需要将django部署到外网) 购买阿里云服务器 到[阿里云官网],选择轻量应用服务器, 步骤如图所示: 地域随便选择哪一个,镜像的话,对比 ...

  3. Java对接微信支付(完整全流程)

    Java对接微信支付及支付回调通知的全流程 一.所用框架.对接微信支付我们技术组用的是payment框架,因为该框架已整合springboot因此很方便快捷 <dependency>< ...

  4. 这份【互联网项目全流程表】,实在是泰裤辣!!!

    互联网行业是一个快速变化的行业,作为半个互联网人.太明白用户和环境每天都在不停地变化是什么感受了. ​从项目开始到项目结束,要经历立项.计划.执行.结项,项目一周一个,一周一个.(**的)为了省时间就 ...

  5. 项目全流程 (1/3)

    目录 前言 一.环境搭建-spring 1.1 IDEA环境搭建 1.1.1 创建项目配置 1.1.2 选择Springboot版本 1.1.3 项目设置 1.1.4 导入pom.xml文件 1.1. ...

  6. storm throw 口袋妖怪_初版storm项目全流程自动化测试代码实现

    由于项目需要,写了版针对业务的自动化测试代码,主要应用场景在于由于业务日趋复杂,一些公共代码的改动,担心会影响已有业务.还没进行重写,但知识点还是不少的与大家分享实践下.首先,介绍下整个流处理的业务流 ...

  7. 【Git】码云Gitee.com管理项目全流程

    Gitee.com 是 OSCHINA.NET 推出的代码托管平台,支持 Git 和 SVN,提供免费的私有仓库托管.目前已有超过 500 万的开发者选择 Gitee. 官网:https://gite ...

  8. python自动化测试项目全流程

    之前做的一个自动化项目,大概总结了一下. 1.先整理好一个完整流程的接口,这里需要导入requests模块,因为涉及到新建需要随机命名的,所以还增加了random模块 2.对接口进行封装(def):接 ...

  9. 【微信小程序】微信支付接入全流程

    一. 前置条件 接入支付首先得需要有企业资质,并开通企业对公户 注册微信支付并进行对公户打款认证 二. 开始接入 1. 下载微信支付的AP证书 2. 服务端接入微信支付 2.1 引入相关maven配置 ...

最新文章

  1. 广播站 PHP,让一实听见你的声音——“校园之声”广播站招募小记
  2. 设置串行端口的通信参数
  3. Acwing第 1 场周赛【完结】
  4. 【android】【转】class android.media.MediaPlayer
  5. 百度地图大数据告诉你一线城市真相
  6. Loj #6274. 数字 数位dp + 去重
  7. 错误代码0x800f0950怎么解决_解决win10安装net framework 3.5失败(错误代码 0x800F0950)...
  8. 物联网99%是中小企业 引发赚快钱担忧
  9. 惠普:某些 SSD 驱动的寿命只有32,768 小时(3年多),立即更新!
  10. 136_原始套接字_链路层MAC包_模仿他人飞秋,给自己主机上的飞秋【发送UDP数据】【只需要修改包含用户名、头像信息的数组】
  11. 【数据结构导论】考试笔记总结(一)
  12. 一个人是否靠谱,闭环很重要
  13. 计算机里的及格率和有优秀率怎么算,excel表格计算优秀及格率的教程
  14. 2,Jenkins实战应用_Jenkins初始部署与简单配置
  15. python毕业设计项目源码选题(10)电影院售票系统毕业设计毕设作品开题报告开题答辩PPT
  16. Win 10 开机出现no bootable device
  17. 查看Ubuntu下的U盘
  18. python语音识别库kaldi_Kaldi 语音识别基础教程
  19. php二手房系统,phpwind房产新版上线 抢先体验二手房新功能
  20. OpenGL实现雾化效果

热门文章

  1. 机器人基础原理1_1——机器人概念及发展历程
  2. VB.NET 教程_03_面向对象
  3. php正态分布,如何在PHP中生成累积正态分布
  4. Angular JS(谷歌旗下的用户界面前端框架)
  5. scrapy抓取豆瓣网信息时报错提醒INFO: Ignoring response <403 https://movie.douban.com/top250>: HTTP status code is
  6. Android分割线View
  7. android实现gif背景透明,透明GIF在Android ImageView
  8. sumo_ns3 交通通信仿真重点步骤详解
  9. AEJoy —— AE 表达式入门基础
  10. DNN(全连接神经网络)