vue實(shí)現(xiàn)todolist基本功能以及數(shù)據(jù)存儲(chǔ)功能實(shí)例詳解
實(shí)現(xiàn)todolist功能,具體實(shí)現(xiàn)如下:
可以實(shí)現(xiàn)對(duì)list添加、移除以及狀態(tài)轉(zhuǎn)變,其中添加功能既可以通過(guò)鼠標(biāo)點(diǎn)擊按鈕實(shí)現(xiàn),也可以通過(guò)回車(chē)鍵按下實(shí)現(xiàn),通過(guò)使用v-model對(duì)checked的值進(jìn)行雙向綁定來(lái)完成狀態(tài)的改變。在本次實(shí)際操作中仍存在一個(gè)小問(wèn)題就是methods中函數(shù)調(diào)用,在完成數(shù)據(jù)存儲(chǔ)前可以通過(guò)this.$options.methods.addFun();
進(jìn)行調(diào)用。
<div id="app"> <input type="text" v-model="msg" @keydown="kaddFun($event)"/> <button @click="addFun()">添加</button> <br /><br /> <h3>進(jìn)行中</h3> <ul> <li v-for="(item,key) in list" v-if="!item.checked"><input type="checkbox" v-model="item.checked" @change="saveList()"/> {{item.title}} <button @click="moveFun(key)">移除</button></li> </ul> <h3>已完成</h3> <ul> <li v-for="(item,key) in list" v-if="item.checked" ><input type="checkbox" v-model="item.checked"/> {{item.title}} <button @click="moveFun(key)">移除</button></li> </ul> </div> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <script type="text/javascript"> var app = new Vue({ el:'#app', data:{ msg:'', list:[] }, methods:{ addFun(){ this.list.push({ title:this.msg, checked:false }), this.msg = ''; //存儲(chǔ)數(shù)據(jù) localStorage.setItem('list',JSON.stringify(this.list)) }, kaddFun(e){ if(e.keyCode==13){ this.addFun(); } }, moveFun(key){ confirm("是否移除"+this.list[key].title+"?"); this.list.splice(key,1); localStorage.setItem('list',JSON.stringify(this.list)) }, saveList(){ localStorage.setItem('list',JSON.stringify(this.list)) } }, //生命周期函數(shù) vue頁(yè)面刷新就會(huì)觸發(fā)的方法 mounted(){ //json字符串轉(zhuǎn)成json對(duì)象 var list = JSON.parse(localStorage.getItem('list')) //判斷l(xiāng)ist是否存在 if(list){ //存在則將獲取到的list保存刷新后的list中 this.list = list; } } }) </script>
封裝操作localstorage本地存儲(chǔ)方法
總結(jié)
以上所述是小編給大家介紹的vue實(shí)現(xiàn)todolist基本功能以及數(shù)據(jù)存儲(chǔ)功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
vue pages 多入口項(xiàng)目 + chainWebpack 全局引用縮寫(xiě)說(shuō)明
這篇文章主要介紹了vue pages 多入口項(xiàng)目 + chainWebpack 全局引用縮寫(xiě)說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09Vue 使用iframe引用html頁(yè)面實(shí)現(xiàn)vue和html頁(yè)面方法的調(diào)用操作
這篇文章主要介紹了Vue 使用iframe引用html頁(yè)面實(shí)現(xiàn)vue和html頁(yè)面方法的調(diào)用操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11vue數(shù)據(jù)更新但視圖(DOM)不刷新的幾種解決辦法
這篇文章主要給大家介紹了關(guān)于vue數(shù)據(jù)更新但視圖(DOM)不刷新的幾種解決辦法,我們?cè)陂_(kāi)發(fā)過(guò)程中經(jīng)常會(huì)碰到數(shù)據(jù)更新,但是視圖并未改變的情況,需要的朋友可以參考下2023-08-08Vue項(xiàng)目本地沒(méi)有問(wèn)題但部署到服務(wù)器上提示錯(cuò)誤(問(wèn)題解決方案)
一個(gè) VUE 的項(xiàng)目在本地部署沒(méi)有問(wèn)題,但是部署到服務(wù)器上的時(shí)候提示訪問(wèn)資源的錯(cuò)誤,遇到這樣的問(wèn)題如何解決呢?下面小編給大家?guī)?lái)了Vue項(xiàng)目本地沒(méi)有問(wèn)題但部署到服務(wù)器上提示錯(cuò)誤的解決方法,感興趣的朋友一起看看吧2023-05-05Node.js使用orm2進(jìn)行update操作時(shí)關(guān)聯(lián)字段無(wú)法修改的解決方法
這篇文章主要給大家介紹了Node.js使用orm2進(jìn)行update操作時(shí)關(guān)聯(lián)字段無(wú)法修改的解決方法,文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-06-06Vue引入jquery實(shí)現(xiàn)平滑滾動(dòng)到指定位置
這篇文章主要介紹了Vue引入jquery實(shí)現(xiàn)平滑滾動(dòng)到指定位置的效果,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2018-05-05