全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

如图,A simple todo-list长这样

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

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

删除效果:

讲一下思路:

上移-----首先将鼠标所指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的上移下移删除功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# vuejs  # todo  # list  # vue3实现一个todo-list  # vue组件编写之todolist组件实例详解  # 使用Vue完成一个简单的todolist的方法  # vue实现留言板todolist功能  # 详解Vue的computed(计算属性)使用实例之TodoList  # 基于vuejs实现一个todolist项目  # vue实现todolist单页面应用  # vue实现ToDoList简单实例  # vue3组合式API实现todo列表效果  # 鼠标  # 该项  # 小编  # 这是  # 很好  # 第一个  # 在此  # 不懂  # 这是一个  # 给大家  # 便可  # 才可以  # 两条  # 如图  # 既可  # 在上  # 中对  # 所述  # 给我留言  # 感谢大家 


相关文章: 制作网站的过程怎么写,用凡科建站如何制作自己的网站?  如何在橙子建站上传落地页?操作指南详解  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  建站之星后台密码如何安全设置与找回?  如何快速生成ASP一键建站模板并优化安全性?  头像制作网站在线制作软件,dw网页背景图像怎么设置?  家庭服务器如何搭建个人网站?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  制作国外网站的软件,国外有哪些比较优质的网站推荐?  制作网站外包平台,自动化接单网站有哪些?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  如何通过可视化优化提升建站效果?  C++如何编写函数模板?(泛型编程入门)  如何打造高效商业网站?建站目的决定转化率  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  建站主机类型有哪些?如何正确选型  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  如何做网站制作流程,*游戏网站怎么搭建?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  宝塔建站教程:一键部署配置流程与SEO优化实战指南  实例解析angularjs的filter过滤器  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  定制建站策划方案_专业建站与网站建设方案一站式指南  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  深圳网站制作培训,深圳哪些招聘网站比较好?  建站之星收费标准详解:套餐费用及年费价格表一览  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  如何通过山东自助建站平台快速注册域名?  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  建站之星代理如何获取技术支持?  h5网站制作工具有哪些,h5页面制作工具有哪些?  制作网站的公司有哪些,做一个公司网站要多少钱?  教学论文网站制作软件有哪些,写论文用什么软件 ?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  大学网站设计制作软件有哪些,如何将网站制作成自己app?  如何选择高效响应式自助建站源码系统?  东莞专业制作网站的公司,东莞大学生网的网址是什么?  湖北网站制作公司有哪些,湖北清能集团官网?  如何正确下载安装西数主机建站助手?  如何选择高效可靠的多用户建站源码资源?  如何用西部建站助手快速创建专业网站?  青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  宝塔建站无法访问?如何排查配置与端口问题?  宝塔面板创建网站无法访问?如何快速排查修复?  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  导航网站建站方案与优化指南:一站式高效搭建技巧解析 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。