欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-03 13:51:39
如图,a simple todo-list长这样 这是一个基于vue.js的一个简单的todo-list小demo。首先要实现添加非空list,点击list切换fin...

如图,a simple todo-list长这样

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

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

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

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

删除效果:

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

讲一下思路:

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

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

小二~上代码:

----app.vue---- 

<div><input v-model="newitem" v-on:keyup.enter="addnew"></div> 
<div class="box-center"> 
 <ul class="box-list"> 
  <li v-for="item ,index in items" v-bind:class="{finished:item.isfinished}"  

  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> 
  <span class="list-btn" v-show="item.isshow"> 
   <button v-on:click="moveup(index,item)">上移</button> 
   <button v-on:click="movedown(index,item)">下移</button> 
   <button v-on:click="deletebtn(index)">删除</button> 
  </span> 
 </li> 
</ul>  
t;/div> 

----store.js---- 

const storage_key = 'todos-vuejs' 
export default { 
 fetch () { 
  return json.parse(window.localstorage.getitem( 
   storage_key) || '[]') 
 }, 
 save (items) { 
  window.localstorage.setitem(storage_key,json.stringify( 
   items)) 
 } 
} 
----app.vue---- 
<span style="font-size:14px;"><script> 
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,0,(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,0,(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); 
  } 
 }, 
} 
</script></span><span style="font-size: 18px;"> 
</span> 

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

总结:

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

以上所述是小编给大家介绍的vue.js实现一个todo-list的上移下移删除功能,希望对大家有所帮助