纯Vue实现网页日常任务清单小功能(数据存储在浏览器)
任务清单可以极大提高我们的工作效率、哪些事情办了、哪些事情代办、哪些是紧急需要办的事情等等。
在组件化编码实战3的基础上进一步改进、将原先的数据保存的浏览器中。就可以做到关闭网页也不会丢失数据的情况
组件化编码实战3:https://blog.csdn.net/weixin_43304253/article/details/126256518
文章目录
- 1、功能描述
- 2、效果演示
- 3、在实战三代码上修改(核心部分代码、将数据保存到浏览器)
- 4、已经打包好的项目(包含项目源码)
- 5、友情提示
1、功能描述
- 1、可以添加当天的任务到任务清单
- 2、可以勾选已经完成的项目
- 3、统计任务数量以及完成数量
- 4、删除已完成的任务
- 5、可以查看当天的任务清单(关闭网页重新打开同样可以看到)
2、效果演示
视频链接:https://live.csdn.net/v/230827
3、在实战三代码上修改(核心部分代码、将数据保存到浏览器)
<template><div id="root"><div class="todo-container"><div class="todo-wrap"><TheHeader :addTodo="addTodo" /><TheList:todos="todos":checkTodo="checkTodo":deleteTodo="deleteTodo"/><TheFooter:todos="todos":checkAllTodo="checkAllTodo":clearAllTodo="clearAllTodo"/></div></div></div>
</template><script>
import TheHeader from "./components/TheHeader";
import TheList from "./components/TheList";
import TheFooter from "./components/TheFooter.vue";export default {name: "App",components: { TheHeader, TheList, TheFooter },data() {return {//由于todos是MyHeader组件和MyFooter组件都在使用,所以放在App中(状态提升)todos: JSON.parse(localStorage.getItem("todos")) || [],// todos: [// { id: "001", title: "吃饭", done: true },// { id: "002", title: "睡觉", done: false },// { id: "003", title: "打豆豆", done: true },// ],};},methods: {//添加一个todoaddTodo(todoObj) {this.todos.unshift(todoObj);},//勾选or取消勾选一个todocheckTodo(id) {this.todos.forEach((todo) => {if (todo.id === id) todo.done = !todo.done;});},//删除一个tododeleteTodo(id) {this.todos = this.todos.filter((todo) => todo.id !== id);},//全选or取消全选checkAllTodo(done) {this.todos.forEach((todo) => {todo.done = done;});},//清除所有已经完成的todoclearAllTodo() {this.todos = this.todos.filter((todo) => {return !todo.done;});},},watch: {todos: {deep: true,handler(value) {localStorage.setItem("todos", JSON.stringify(value));},},},
};
</script><style>
/*base*/
body {background: #fff;
}
.btn {display: inline-block;padding: 4px 12px;margin-bottom: 0;font-size: 14px;line-height: 20px;text-align: center;vertical-align: middle;cursor: pointer;box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2),0 1px 2px rgba(0, 0, 0, 0.05);border-radius: 4px;
}
.btn-danger {color: #fff;background-color: #da4f49;border: 1px solid #bd362f;
}
.btn-danger:hover {color: #fff;background-color: #bd362f;
}
.btn:focus {outline: none;
}
.todo-container {width: 600px;margin: 0 auto;
}
.todo-container .todo-wrap {padding: 10px;border: 1px solid #ddd;border-radius: 5px;
}
</style>
4、已经打包好的项目(包含项目源码)
目的是方便自己保存项目代码(便于自己学习、节省自己的电脑磁盘)
地址链接:https://download.csdn.net/download/weixin_43304253/86403872
5、友情提示
这里已给出将数据存储到浏览器中的核心代码。不怎么需要去看整个项目的代码了
纯Vue实现网页日常任务清单小功能(数据存储在浏览器)相关推荐
- 任务清单小功能的实现(任务的增、删、改、查、存储)使用Vue实现
文章目录 1.实现的效果(视频演示) 2.重点讲解(编辑的实现) 2.1 提示(官网介绍nextTick的用法) 3.编辑功能的核心代码 4.完整的代码 5.以往练习 任务清单案例(纯Vue) 实现的 ...
- 微信小程序数据存储与取值
在小程序开发的过程,经常要需要这个页面输入的数据,在下一个页面中进行取值赋值. 比如: 在A页面input输入框,输入电话号码,点击添加.需要在B页面电话区域中,显示刚刚输入的电话号码. 因为这是两个 ...
- 微信小程序数据存储长时间缓存数据,数据存储本地
安卓和小程序体验 小程序体验 安卓版本体验 安卓体验download 数据存储 使用场景 许多时候我们需要将用户的数据保存到本地,以便以后的调用.比如说openid,如果每次打开小程序都需要发送cod ...
- 微信小程序如何从数组里取值_微信小程序数据存储与取值详解
在小程序开发的过程,经常要需要这个页面输入的数据,在下一个页面中进行取值赋值. 比如: 在A页面input输入框,输入电话号码,点击添加.需要在B页面电话区域中,显示刚刚输入的电话号码. 因为这是两个 ...
- HTML+JavaScript为网页添一点小功能【尼尔机械纪元】
功能一:添加了图片转换功能 let myImage = document.querySelector('img'); myImage.onclick = function() {//将函数和事件绑定l ...
- PHP的postman的bulk edit小功能:可以直接复制浏览器query string parameters的数据至postman的body的form-data 很方便 不用手写了
- 微信小程序--数据存储
对本地缓存数据操作分为同步和异步两种.同步方法有成功回调函数,表示数 据处理成功后的操作.下面是小程序提供本地缓存操作接口: 以Sync结尾都是同步方法.同步方法和异步方法的区别是: 同步方法会堵塞当 ...
- 微信小程序---数据存储
微信小程序存储方式有两种:同步和异步. 保存数据有以下两种方式: wx.setStorage 异步保存 wx.setStorageSync同步保存 获取数据也是两种: wx.getStorage 异步 ...
- 微信小程序与内嵌网页交互实现支付功能
上个月,小程序开放了新功能,支持内嵌网页,所以我就开始了小程序内嵌网页之路,之前我只是个小安卓. 内嵌网页中可使用JSSDK 1.3.0提供的接口,可坑就来了,居然不支持支付接口的调用,经过一番研究, ...
- vue实现网页端企业微信扫码登录功能(前端部分)
时至今日,企业微信在企业日常工作中的使用越来越频繁也越来越重要,不少企业已使用企业微信进行着日常的工作安排管理.在这种背景下,各类系统和企业微信对接的需求也不断增加,今天要说的就是一个比较常见的需求 ...
最新文章
- 2 构建Mysql+heartbeat+DRBD+LVS集群应用系统系列之MySql的搭建
- android 将数据转换成JSON数据格式并使用JSONObject解析JSON格式的数据
- 荷兰警方错买300万欧元Office套件 法院:微软无需退款
- 别被忽悠了!阿里内部人士:我们正悄悄地拆掉中台,你还在建?
- 团队开发——用户需求报告
- MySQL把一个大表拆分多个表后,如何解决跨表查询效率问题
- 大数据: 城市转型发展新的驱动力
- StarUML接口视图修改为类的形式
- 想入行SAP咨询,最具性价比的方式
- HTML:Boostarp设计登录页面
- GIS应用技巧之空间插值理论介绍
- 卷积神经网络原理简述
- Android一键加群实现
- 牛客网-前端刷题记录(简单级)
- namesilo修改域名服务器,Namesilo, godaddy和万网域名修改NS的方法
- 三天打渔,两天晒网(java)
- 前端:让我们做一个快乐的切图仔!
- 生产管理系统是什么?它有哪些功能模块?
- keil 对于 ERROR: FILE DOES NOT EXIST错误的解决办法
- Docker 及 Docker Compose 安装及使用教程 (2020版)