如图,A simple todo-list长这样
这是一个基于vue.js的一个简单的todo-list小demo。首先要实现添加非空list,点击list切换finished状态这样的一个效果,推荐学习地址---->链接
讲一下思路:
上移-----首先将鼠标所指list的内容插入到上一条上面,然后删除鼠标所指的list(也就是this.items[index]),运行代码便可实现上移的效果,或者将上下两条list的内容进行调换也是可以的。
删除-----这里和上下移一样,主要是用到了操作数组的splice这个方法,既可以添加也可以删除,不懂的去补一下
小二~上代码:
----App.vue----
Box-center">
- Box-list">
- 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)">删除
----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的上移下移删除功能。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持。