vue的todolist的分析

在vue中computed计算属性,依赖项目不光可以是data的数据,还可以是其余的计算属性
@sublim.prevent=“addTodo”
@sublim.top=“addTodo”
form 用了才能有required这个属性

方法写在methos中,不看以写在计算属性中 computed:{ addToto(){ conosle.log('322') } }

方法写在methos中
computed:{
addToto(){
conosle.log(‘322’)
}
}

问题是:

从上面往下勾选,会出现不良的反应

解析:vue的底层为做更好优化,在相同的元素的地方尽可能的去做了复用元素的操作
出现的原因是:diff算法引起的
解决方案:
一切v-for的时候,给每一项都加上key这个属性,属性值在每一项中保持唯一
key的值一般使用循环时每一项的id属性来控制(推荐)
如果实在没有id的时候,使用循环的下标也行
但是如果有元素移除的时候,要注意
v-for一定要使用key

从下面往数点没有问题

要删除当前的元素,可以定义一个方法delTodo(item.id)
@click=“delTodo(item.id)”
// 根据传过来的id做删除功能
数组.splice(下标,1) 完成删除工作
在methods中定义方法,注意不要搞错了在(computed)中
1.根据id去寻找todos中对应的id的项目的下标find|| findIndex
findIndex找数组对应的下标
获取下标
let index=this.todos.,findIndex((Item)=>{
return item.id===id
})
2.根据下标来删除
this.todos.splice(index,1)
3.全部删除
delAll(){
this.todos=[]
}

4.刷新页面还在,可以用localStroage保存起来
在删除和添加和清空需要保存
localStroage不能存储数组对象(要换JSON.stringify(数组)),只能储存字符串
注意将数组先转换
如果多个地方需要用存储功能,可以定义一个方法
//保存操作
saveTodo(){
window.localStroage.setItem(‘todos’,JSON.stringify(this.todos))
}
对象的属性做修改,监听没有识别到,所以需要用到深度监听
watch:{
//深度监听,要写成对象的形式
todos:{
handler(){
this.saveTodo()
},
deep:true//深度监听
}
保存操作,和页面刷新回来
可以在created中,去做
或者在data中去做
存储的是json,取出来的时候,要转为parse格式
data:{
// 注意:
// 1.是否存在
// 2.存在要解析成数组
// 判断有没有,有就把它解析成对象, 没有就为空对象
todos:window.localStorage.getItem(“todos”)?
JSON.parse(window.localStorage.getItem(“todos”)):[],
title:""
// 这种是错误的
// todos:window.localStorage.getItem(“todos”) 没有数据,它这里是把undefined拿去解析
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue Todolist 是一个基于 Vue.js 框架开发的任务清单应用。通过使用 Vue.js 的响应式数据绑定和组件化开发的特性,可以实现动态更新数据和交互效果。 首先,我们可以使用 Vue 的模板语法来编写任务清单的布局和 HTML 结构。通过 v-for 指令可以循环渲染任务列表,使得我们可以方便地添加、编辑和删除任务。 其次,通过使用 Vue 的计算属性,我们可以实现对任务列表进行过滤和排序操作。比如可以根据任务状态(已完成、未完成)来显示不同的任务列表,也可以根据任务的添加时间或者截止时间来进行排序。 在交互方面,我们可以使用 Vue 的事件绑定机制来实现添加、编辑和删除任务的功能。比如,可以使用 v-on 指令绑定点击事件,当用户点击添加按钮时,会触发相应的方法来添加新的任务到任务列表中。 另外,我们可以通过使用 Vue 的指令和表单元素的双向数据绑定来实现任务的编辑功能。当用户点击某个任务的编辑按钮时,可以根据该任务的索引值,展示一个输入框供用户编辑任务内容,完成编辑后,会自动将编辑后的内容更新到任务列表中。 最后,我们可以使用 Vue 的路由功能来实现多个页面之间的切换。比如可以添加一个导航栏,每个导航项对应一个页面,点击导航项时,会切换到对应的页面,从而实现任务清单的不同视图切换。 综上所述,Vue Todolist 是一个基于 Vue.js 框架开发的任务清单应用,通过利用 Vue.js 的特性,可以实现数据的实时更新和交互效果,提供灵活的任务管理功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值