加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Vue.js实现一个todo-list的上移下移删除功能

发布时间:2020-12-17 02:54:33 所属栏目:百科 来源:网络整理
导读:如图,A simple todo-list长这样 这是一个基于vue.js的一个简单的todo-list小demo。首先要实现添加非空list,点击list切换finished状态这样的一个效果,推荐学习地址----> 接下来是实现的一个上移,下移,删除的效果图: 删除效果: 讲一下思路: 上移-----

如图,A simple todo-list长这样

这是一个基于vue.js的一个简单的todo-list小demo。首先要实现添加非空list,点击list切换finished状态这样的一个效果,推荐学习地址---->

接下来是实现的一个上移,下移,删除的效果图:

删除效果:

讲一下思路:

上移-----首先将鼠标所指list的内容插入到上一条上面,然后删除鼠标所指的list(也就是this.items[index]),运行代码便可实现上移的效果,或者将上下两条list的内容进行调换也是可以的。

删除-----这里和上下移一样,主要是用到了操作数组的splice这个方法,既可以添加也可以删除,不懂的去补一下

小二~上代码:

----App.vue----

v-on:mouSEOver="moveBtn(item)" v-on:mouSEOut="leaveBtn(item)">
<span v-on:click="toggleFinished(item)" v-bind:class="{bgYellow:item.isBgyellow}">{{item.label}}
<span class="list-btn" v-show="item.isShow">
<button v-on:click="moveUp(index,item)">上移
<button v-on:click="moveDown(index,item)">下移
<button v-on:click="deleteBtn(index)">删除

t;/div>

----Store.js----

import Store from './store' export default { data: function() { return { title: 'A simple todo-list',items: Store.fetch(),newItem: '',msg:'点击按钮',isShow: false,isBlock: true,isBgyellow: false,leftPx:0,topPx:0 } },watch: { items: { handler: function(items) { Store.save(items) },deep: true } },methods: { toggleFinished: function(item) { item.isfinished = !item.isfinished },show:function ($event) { $event.cancelBubble=true; this.isBlock = false; this.topPx = ($event.clientY); this.leftPx = ($event.clientX); },stop:function(event){ this.isBlock = true; },moveBtn:function(item) { // console.log(item.label) item.isShow = true; },leaveBtn:function(item) { item.isShow = false; },addNew: function() { //非空才可以添加 if(this.newItem!=''){ this.items.push({ label: this.newItem,isfinished: false }) } this.newItem = ''; },moveUp:function(index,item) { //在上一项插入该项 this.items.splice(index-1,(this.items[index])); //删除后一项 this.items.splice(index+1,1); item.isShow = false; if(index == 0) { alert("到顶啦!"); } },moveDown:function(index,item) { //在下一项插入该项 this.items.splice(index+2,(this.items[index])); // 删除前一项 this.items.splice(index,1); item.isShow = false; if(index == this.items.length-1) { alert("已经是最后一项啦!"); } },deleteBtn:function(index) { this.items.splice(index,1); } },}

套路就是在html中插入方法或者class,methods中对数据进行操作~

总结:

这是本小白入门vue.js学习的第一个demo,有一些jQuery的观念不能很好的转变,总是习惯性的操作dom节点,殊不知vue可以有更好的方式去实现

以上所述是小编给大家介绍的Vue.js实现一个todo-list的上移下移删除功能。编程之家 52php.cn 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读