Vue.js实现一个todo-list的上移,下移,删除功能
来源:互联网 发布:网络黄金egd充值 编辑:程序博客网 时间:2024/06/10 18:23
如图,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> </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----
<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>
套路就是在html中插入方法或者class,methods中对数据进行操作~
总结:
这是本小白入门vue.js学习的第一个demo,有一些jquery的观念不能很好的转变,总是习惯性的操作dom节点,殊不知vue可以有更好的方式去实现,
接下来这个项目还有新的需求(将功能收进右键菜单中,增加更换背景色的按钮),希望能对你有所帮助~
阅读全文
1 0
- Vue.js实现一个todo-list的上移,下移,删除功能
- vue.js实现的一个todo list
- JS实现上移下移功能
- Flex中List实现上移下移功能
- FLex List 实现上移下移功能
- Flex中List实现上移下移功能
- js上移下移功能
- js 脚本实现 上移下移功能
- VUE案例 todolist 上移下移置顶 删除
- 使用Vue.js完成一个todo-list
- js实现上移下移效果
- js实现上移、下移置顶
- vue.js 实现 todo list 任务表单
- VB DataGridView中上移下移功能的实现
- jquery 实现列表上移、下移功能
- 通用的排序的上移下移功能
- 表格数据的上移与下移功能
- 上移、下移功能
- 手把手教你使用 Raspberry
- 4.2-全栈Java笔记:对象和类的概念及定义
- strcpy vs memcpy vs memmove
- 执行linux中bin目录下的程序
- 博客链接笔记
- Vue.js实现一个todo-list的上移,下移,删除功能
- 动态加载script标签
- 简述死锁
- 栈 实际应用1 如何使用栈来判定括号是否匹配
- ffmpeg 函数简单分析 : av_register_all()
- Oracle执行计划详解
- Java Map遍历方式方式及性能测试
- 栈应用2 中缀表达式转后缀表达式
- 判断是否是质数