微信小程序TodoList如何使用
这篇文章主要介绍"微信小程序TodoList如何使用",在日常操作中,相信很多人在微信小程序TodoList如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"微信小程序TodoList如何使用"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
之前都用JQ、Backbone、vue简单撸过,大概功能如下:
添加todo
储存在应用缓存
列表展示
区分状态显示:全部、未完成、已完成
改变todo状态
删除todo
1小程序手指缩放图片开发过程
下载小程序开发工具:开发者工具下载
安装完成后,使用微信扫一扫登录,选好文件夹后创建即可,开发工具会自动生成以下目录:
pages/
app.js
app.json
app.wxss
2基本配置
由于平时开发习惯用Less,如果在直接使用小程序的wxss来编写的话,就恢复原生编写方式,大大的不便,所以直接使用了gulp来实时编译Less,和修改文件名为wxss。小程序开发工具是不支持Less,直接用vscode来开发,小程序开发工具是用实时预览和调试即可,vscode也有丰富的插件支待小程序语法提示。
// gulpfile.jsvar gulp = require('gulp')var less = require('gulp-less')var plumber = require('gulp-plumber')var rename = require('gulp-rename')gulp.task('less', function () { return gulp.src('./app.less') .pipe(plumber()) // 错误处理 .pipe(less()) // 编译less .pipe(rename((path) => path.extname = '.wxss')) // 编译后生成文件修改后缀为.wxss .pipe(gulp.dest('./'));});gulp.watch('./app.less', ['less']); // 实时监控app.less文件变化,运行任务
UI组件也直接引用了小程序支持的weui-wxss
@import "./weui.wxss";
在app.json定义好小程序页面路由和配色:
{ "pages":[ "pages/index/index" ], "window":{ "backgroundTextStyle":"light", "navigationBarBackgroundColor": "#ca2100", "navigationBarTitleText": "TodoList", "navigationBarTextStyle":"white" }}
3页面开发
页面文件都存放在pages/目录下,每个功能页面都会创建一个文件夹,TodoList现只需一个页面完成即可
数据绑定使用 Mustache 语法(双大括号)将变量包起来
{{userInfo.nickName}}全部
添加todo
使用字段addShow
来判断添加输入层显示隐藏即可
input输出框这里不是双向绑定,所以这里添加一个事件bindinput="setInput"
来赋值实时变化
实时赋值事件处理
setInput: function (e) { this.setData({ addText: e.detail.value })}
取消时,需要清空input的值,input里需要绑定value="{{addText}}"
Page({ data:{ //... }, //... addTodoHide: function () { this.setData({ addShow: false, // 控制添加输入面板隐藏 focus: false, // 失去焦点 addText: '' // 清空值 }) } //...})
添加todo
Page({ data:{ //... }, //... addTodo: function () { // 检查有没有输入 if (!this.data.addText.trim()) { return } var temp = this.data.lists // 取出lists var addT = { id: new Date().getTime(), // 取当前时间 title: this.data.addText, status: '0' } temp.push(addT) // 添加新的todo this.showCur(temp) // 处理当前状态的方法 this.addTodoHide() // 添加成功后,隐藏添加面板方法 wx.setStorage({ // 小程序异步缓存 key:"lists", data: temp }) wx.showToast({ // weui toast组件 title: '添加成功!', icon: 'success', duration: 1000 }); } //...})
列表部分
scroll-view内滚动
列表渲染,事件触发,利用data传参,bind绑定事件
暂无数据{{item.title}}{{api.formatTime(item.id)}}删除
滑动删除
效果:当向左滑动时,content跟随手指像左移动,同时右侧出现del按钮;当滑动距离大于按钮宽度一半松开手指时自动滑动到左侧显示出按钮,小于一半时自动回到原来的位置,隐藏按钮。
实现思路:content和del按钮分别是绝对定位,利用z-index层来控制让content来盖住del,当content向左滑动时,del按钮就会露出来。
微信小程序api提供的touch对象和3个有关手指触摸的函数(touchstart,touchmove,touchend)来实现content随手指移动
列表的content已绑定这个三个事件:bindtouchstart="touchS" bindtouchmove="touchM" bindtouchend="touchE"
实现方法:
注意txtStyle
,在content在绑定这个属性的,实现跟随手指移动的
delBtnWidth
为了del按钮的宽度,这里以rpx为单位
Page({ data:{ //... }, //... touchS: function (e) { // console.log('开始:' + JSON.stringify(e)) // 是否只有一个触摸点 if(e.touches.length === 1){ this.setData({ // 触摸起始的X坐标 startX: e.touches[0].clientX }) } }, touchM: function (e) { // console.log('移动:' + JSON.stringify(e)) var _this = this if(e.touches.length === 1){ // 触摸点的X坐标 var moveX = e.touches[0].clientX // 计算手指起始点的X坐标与当前触摸点的X坐标的差值 var disX = _this.data.startX - moveX // delBtnWidth 为右侧按钮区域的宽度 var delBtnWidth = _this.data.delBtnWidth var txtStyle = '' if (disX == 0 || disX < 0){ // 如果移动距离小于等于0,文本层位置不变 txtStyle = 'left:0' } else if (disX > 0 ){ // 移动距离大于0,文本层left值等于手指移动距离 txtStyle = 'left:-' + disX + 'rpx' if(disX >= delBtnWidth){ // 控制手指移动距离最大值为删除按钮的宽度 txtStyle = 'left:-' + delBtnWidth + 'rpx' } } // 获取手指触摸的是哪一个item var index = e.currentTarget.dataset.index; var list = _this.data.curLists // 将拼接好的样式设置到当前item中 list[index].txtStyle = txtStyle // 更新列表的状态 this.setData({ curLists: list }); } }, touchE: function (e) { // console.log('停止:' + JSON.stringify(e)) var _this = this if(e.changedTouches.length === 1){ // 手指移动结束后触摸点位置的X坐标 var endX = e.changedTouches[0].clientX // 触摸开始与结束,手指移动的距离 var disX = _this.data.startX - endX var delBtnWidth = _this.data.delBtnWidth // 如果距离小于删除按钮的1/2,不显示删除按钮 var txtStyle = disX > delBtnWidth/2 ? 'left:-' + delBtnWidth + 'rpx' : 'left:0' // 获取手指触摸的是哪一项 var index = e.currentTarget.dataset.index var list = _this.data.curLists list[index].txtStyle = txtStyle // 更新列表的状态 _this.setData({ curLists: list }); } } //...})
到此,关于"微信小程序TodoList如何使用"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!