文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue如何实现本地存储添加删除修改功能

2023-06-21 20:09

关注

这篇文章给大家分享的是有关vue如何实现本地存储添加删除修改功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

具体内容如下

实现功能:

输入的内容添加到正在进行列表中,

双击修改功能,

点击esc键,取消,还是之前的内容,

点击回车,修改成功,

修改框失焦时修改成功,

选中按钮时进入已完成列表,未选中时在正在进行中列表,

点击删除进行删除当行,

本地存储下次打开上次添加的还在

<!DOCTYPE html><html> <head>  <meta charset="utf-8">  <title></title>  <style type="text/css">  *{   padding: 0;margin: 0;  }   ul{    list-style: none;   }   li{    width: 220px;    height: 40px;    border: 1px solid gainsboro;    margin-top: 4px;    display: flex;    justify-content: space-between;    align-items: center;    background-color: #6CE26C;   }   .del{    margin-right: 5px;    border: none;    width: 20px;    height: 20px;    background-color: #008200;   }  </style> </head> <body>  <div id="app">   <!-- 过滤输入内容首尾空白符 -->   <!-- 回车事件 -->   <input type="text" v-model.trim="temp" @keyup.enter="additem()"/>   <!-- 获取正在进行的数量 -->   <h4>正在进行中{{undolist.length}}</h4>   <ul class="list">    <!-- 将正在进行的内容遍历显示出来 -->    <li class="item" v-for="item in undolist" :key="item.name">     <div class="">      <!-- 多选框为未选中false状态 -->     <input type="checkbox" v-model="item.done" />     <!-- 默认为state是0,当双击时state为1,内容赋给tempEdit-->     <span v-show="item.state==0" @dblclick="item.state=1;tempEdit=item.name">{{item.name}}</span>     <!-- input框内容为tempEdit的值,state=1时显示输入框,     点击esc时state为零隐藏,内容还是原来的值,不进行修改,     当回车时state为0就隐藏input框,将修改过得tempEdit,赋给item.name     当失焦时state为0就隐藏input框,将修改过得tempEdit,赋给item.name      -->     <input type="text" v-model="tempEdit" v-show="item.state==1"      @keyup.esc="item.state=0;tempEdit=item.name"     @keyup.enter="item.state=0;item.name=tempEdit"     @blur="item.state=0;item.name=tempEdit"     />     </div>     <!-- 点击删除时删除其内容 -->     <button type="button" @click="removeitem(item)" class="del">X</button>    </li>   </ul>   <!-- 已完成数量 -->   <h4>已经完成{{doneList.length}}</h4>   <ul class="list">    <!-- 将已完成的内容遍历显示出来 -->    <li class="item" v-for="item in doneList" :key="item.name">     <div class="">      <!-- 多选框为选中true状态 -->     <input type="checkbox" v-model="item.done" />     <!-- 默认为state是0,当双击时state为1,内容赋给tempEdit-->     <span v-show="item.state==0" @dblclick="item.state=1;tempEdit=item.name">{{item.name}}</span>     <!-- input框内容为tempEdit的值,state=1时显示输入框,     点击esc时state为零隐藏,内容还是原来的值,不进行修改,     当回车时state为0就隐藏input框,将修改过得tempEdit,赋给item.name     当失焦时state为0就隐藏input框,将修改过得tempEdit,赋给item.name      -->     <input type="text" v-model="tempEdit" v-show="item.state==1"      @keyup.esc="item.state=0;tempEdit=item.name"     @keyup.enter="item.state=0;item.name=tempEdit;"     @blur="item.state=0;item.name=tempEdit;"     />     </div>     <!-- 点击删除时删除其内容 -->     <button type="button" @click="removeitem(item)" class="del">X</button>    </li>   </ul>  </div> </body> <script src="js/vue.js" type="text/javascript" charset="utf-8"></script> <script type="text/javascript">  var vm=new Vue({   el:"#app",   data(){    return{     // 清单列表     // getItem是获取本地存储数据,     // ||"[]"如果获取不到转换为空的数组     list:JSON.parse(localStorage.getItem("list")||"[]"),     // 临时添加的数据存放处     temp:'',     // 修改框的临时数据存放处     tempEdit:''    }   },   methods:{    // 添加    additem(){     // 文本框为空时就返回     if(this.temp===""){return;}     // 添加到后面     this.list.push({      name:this.temp,      done:false,      state:0     })     // 清空临时框     this.temp="";    },    // 删除    removeitem(item){     // 弹框     var flag=window.confirm("确定要删除吗?");     if(flag){      // 查找符合条件元素的索引值      var ind=this.list.findIndex(value=>value.title===item.title);      // splice从第ind删除一个      this.list.splice(ind,1);     }    }   },   computed:{    // 通过计算把现有的list数据计算出已完成和未完成    // 未完成    undolist(){     // filter数组的过来函数,如果返回结果为真则当前遍历的数据保留     // 否则就会被过滤掉     return this.list.filter(item=>!item.done);         },    // 已完成    doneList(){     return this.list.filter(item=>item.done);    }   },   watch:{    "list":{     handler(){      // setItem设置本地数据      // JSON.stringify把js对象转换为json字符串      // JSON.prase把字符串转换为js对象      localStorage.setItem("list",JSON.stringify(this.list))     },     deep:true,    }   }  }) </script></html>

vue如何实现本地存储添加删除修改功能

感谢各位的阅读!关于“vue如何实现本地存储添加删除修改功能”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯