TodoList

博客班级 https://edu.cnblogs.com/campus/zjcsxy/SE2020
作业要求 https://edu.cnblogs.com/campus/zjcsxy/SE2020/homework/11334
作业目标 1. 编写一个小程序,可以全新编写,也可以学习别人的小程序进行修改 2. 熟悉git代码管理流程,将源代码上传到到github 3. 在博客园班级中写一篇相应的博文
作业源代码 https://github.com/czwzy2017/WeChat-app-TodoList
学号 31801138
院系 浙大城市学院计算分院

前言

第一次接触小程序,先从github上下载了一个他人的小程序进行学习。

原小程序GitHub地址:https://github.com/charleslo1/weapp-todo

然后去掉了一些我觉得没啥必要的功能,添加了一个清除已完成功能。

界面展示

文件结构

components/checkbox 勾选框组件

components/todo-item 任务条目组件

models/Todo.js todo数组模块

pages/todo/index 主页面

pages/todo/create 创建任务页面

pages/store/todoStore.js 对todo的一系列操作

功能

读取用户信息

    wx.getUserInfo({
success: (res) => {
// 可以将 res 发送给后台解码出 unionId
this.globalData.userInfo = res.userInfo
}
})

当小程序隐藏或退出时,保存数据

  onHide() {
todoStore.save()
},
onError() {
todoStore.save()
}
})

长按删除

 handleTodoLongTap(e) {
// 获取 index
let index = e.currentTarget.dataset.index
wx.showModal({
title: '删除提示',
content: '确定要删除这项任务吗?',
success: (e) => {
if (e.confirm) {
this.data.todos.splice(index, 1)
this.update()
}
}
})
}

删除所有已完成

handleDeleteTodo(e){
for (var i=0;i<this.data.todos.length;i++){
if ((this.data.todos[i].completed)==true){
this.data.todos.splice(i,1);
i--;
}
}
this.update() }

首次起用时,会在页面上显示各种操作提示

  __init() {
let isInited = wx.getStorageSync('__todos_inited__')
if (isInited) return
this.todos = this.todos.concat([new Todo({
title: '欢迎使用TodoList',
completed: false,
level: 1,
createdAt: new Date()
}), new Todo({
title: '点击左边勾选框完成一项任务',
completed: false,
level: 1,
createdAt: new Date()
}), new Todo({
title: '点击标题可以编辑任务哦',
completed: false,
level: 2,
createdAt: new Date()
}), new Todo({
title: '点击右边日期可修改日期',
completed: false,
level: 3,
createdAt: new Date()
}), new Todo({
title: '点击下面的 + 新建一项任务吧',
completed: false,
level: 4,
createdAt: new Date()
}), new Todo({
title: '点击下面的 - 可以清除所有已完成',
completed: false,
level: 4,
createdAt: new Date()
}), new Todo({
title: '长按可删除任务',
completed: false,
level: 4,
createdAt: new Date()
}),new Todo({
title: '这是一条已完成的任务1',
completed: true,
level: 4,
date: new Date('2017/11/18'),
createdAt: new Date(),
completedAt: new Date('2017/11/18')
}), new Todo({
title: '这是一条已完成的任务2',
completed: true,
level: 4,
date: new Date('2017/11/19'),
createdAt: new Date(),
completedAt: new Date('2017/11/19')
}), new Todo({
title: '这是一条已完成的任务3',
completed: true,
level: 4,
date: new Date('2017/11/20'),
createdAt: new Date(),
completedAt: new Date('2017/11/20')
}), new Todo({
title: '这是一条已完成的任务4',
completed: true,
level: 4,
date: new Date('2017/11/20'),
createdAt: new Date(),
completedAt: new Date('2017/11/20')
})])
this.save()
wx.setStorageSync('__todos_inited__', true)
}

保存数据至本地

 save() {
wx.setStorageSync(this.key, this.todos)
}
}

添加计划

Page({

  /**
* 页面的初始数据
*/
data: {
// todo
todo: new Todo(), // 级别
levels: ['紧急且重要', '重要不紧急', '紧急不重要', '不紧急不重要']
}, /**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
this.data.todo = new Todo()
this.update()
}, /**
* 分享
*/
onShareAppMessage: function (options) { }, /**
* Todo 改变事件
*/
handleTodoItemChange (e) {
let todo = e.detail.data.todo
Object.assign(this.data.todo, todo)
this.update()
}, /**
* 级别改变事件
*/
handleLevelChange(e) {
this.data.todo.level = parseInt(e.detail.value) + 1
this.update()
}, /**
* 描述输入事件
*/
handleDescChange (e) {
this.data.todo.desc = e.detail.value
this.update()
}, /**
* 取消按钮点击事件
*/
handleCancelTap (e) {
wx.navigateBack()
}, /**
* 保存按钮点击事件
*/
handleSaveTap(e) {
todoStore.addTodo(this.data.todo)
todoStore.save()
wx.navigateBack()
}, /**
* 更新数据
*/
update (data) {
data = data || this.data
this.setData(data)
}
})

微信小程序-TodoList的更多相关文章

  1. 初学微信小程序 TodoList

    微信小程序的学习 微信小程序的开始尝试 TodoList 微信开发者工具生成 目录如下: . |-- app.js |-- app.json |-- app.wxss |-- pages | |-- ...

  2. 近期热门微信小程序demo源码下载汇总

    近期微信小程序demo源码下载汇总,乃小程序学习分析必备素材!点击标题即可下载: 即速应用首发!原创!电商商场Demo 优质微信小程序推荐 -秀人美女图 图片下载.滑动翻页 微信小程序 - 新词 GE ...

  3. 微信小程序学习指南

    作者:初雪链接:https://www.zhihu.com/question/50907897/answer/128494332来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

  4. 微信小程序的应用及信息整合,都放到这里了

    微信小程序终于开始公测了,这篇文章也终于可以发布了. 这篇文章可以说是微信小程序系列三部曲最后一篇.8 月份,小程序推出前,我写了<别开发 app 了>详细阐述了为什么创业应该放弃原生 a ...

  5. 微信小程序导航:官方工具+精品教程+DEMO集合(1月7更新)

    1:官方工具:https://mp.weixin.qq.com/debug/w ... tml?t=14764346784612:简易教程:https://mp.weixin.qq.com/debug ...

  6. 微信小程序 教程及示例

    作者:初雪链接:https://www.zhihu.com/question/50907897/answer/128494332来源:知乎著作权归作者所有,转载请联系作者获得授权.微信小程序正式公测, ...

  7. 微信小程序资料集合

    一:官方地址集合: 1:官方工具:https://mp.weixin.qq.com/debug/wxadoc/dev/devtools/download.html?t=1476434678461 2: ...

  8. 微信小程序踩坑集合

    1:官方工具:https://mp.weixin.qq.com/debug/w ... tml?t=1476434678461 2:简易教程:https://mp.weixin.qq.com/debu ...

  9. 微信小程序开发学习资料

    作者:初雪链接:https://www.zhihu.com/question/50907897/answer/128494332来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

随机推荐

  1. GAN生成的评价指标 Evaluation of GAN

    传统方法中,如何衡量一个generator ?-- 用 generator 产生数据的 likelihood,越大越好. 但是 GAN 中的 generator 是隐式建模,所以只能从 P_G 中采样 ...

  2. std(标准库)和STL(标准模板库)的关系

    C++标准库的内容分为10类: C1.语言支持 C2.输入/输出 C3.诊断 C4.一般工具 C5.字符串 C6.容器 C7.迭代器支持 C8.算法 C9.数值操作 C10.本地化: 下面分类详解: ...

  3. SQLMAP注入Access数据库

    今天偶遇一Access数据库 1.首先尝试是否存在注入点,and1=1,and 1=2,发现返回信息不一样 2.使用sqlmap脱裤,发现时Access数据库,不能提权, 3.那就直接暴库吧,sqlm ...

  4. Java安全之Commons Collections1分析(三)

    Java安全之Commons Collections1分析(三) 0x00 前言 继续来分析cc链,用了前面几篇文章来铺垫了一些知识.在上篇文章里,其实是硬看代码,并没有去调试.因为一直找不到JDK的 ...

  5. 第一月多测师讲解_ linux_vim命令_004

    一. vi/vim 编辑器共分为三种模式: 命令模式(Command mode),"ESC" 输入模式(Insert mode) 底线命令模式(Last line mode) 命令 ...

  6. Prometheus 入门教程(一):Prometheus 快速入门

    文章首发于[陈树义]公众号,点击跳转到原文:https://mp.weixin.qq.com/s/ZXlBPHGcWeYh2hjBzacc3A Prometheus 是任何一个高级工程师必须要掌握的技 ...

  7. python -re库

    正则表达式的语法 正则表达式语法由字符和操作符构成 正则表达式的常用操作符: print("--正则表达式常用操作符--") mata="11356352135 abcd ...

  8. 编程语言那么多,为什么偏偏是C语言成了大学的必修课?

    谁叫你不幸生在中国了?--何祚庥(中国科学院院士) 这是一本给非计算机专业的大学生的C语言的书."我不是学计算机的,为啥要学C语言?"这个问题每年在中华大地都会被问上几百万次. 被 ...

  9. PostgreSQL查询表名称及表结构

    1. 查询表名称 在psql状态下查询表名称 \dt SQL方式查看表名称 SELECT viewname FROM pg_views WHERE schemaname ='public' Postg ...

  10. spring boot:实现图片文件上传并生成缩略图(spring boot 2.3.1)

    一,为什么要给图片生成缩略图? 1, 用户上传的原始图片如果太大,不能直接展示在网站页面上, 因为不但流费server的流量,而且用户打开时非常费时间, 所以要生成缩略图. 2,服务端管理图片要注意的 ...