<template> <div id="app"> <input type="text" v-model='todo' @keydown="doAdd($event)" /> <hr> <br> <h2>進行中</h2> <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="removeData(key)">刪除</button> </li> </ul> <br> <br> <h2>已完成</h2> <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="removeData(key)">刪除</button> </li> </ul> </div> </template> <script> import storage from './model/storage.js'; // console.log(storage); export default { data () { return { todo:'' , list: [] } }, methods:{ doAdd(e){ // console.log(e); if(e.keyCode==13){ this.list.push({ title:this.todo, checked:false }) } storage.set('list',this.list); }, removeData(key){ this.list.splice(key,1) storage.set('list',this.list); } , saveList(){ storage.set('list',this.list); } },mounted(){ /*生命週期函數 vue頁面刷新就會觸發的方法*/ var list=storage.get('list'); if(list){ /*注意判斷*/ this.list=list; } } } </script> <style lang="scss"> .finish{ li{ background:#eee; } } </style>
//封裝操做localstorage本地存儲的方法 模塊化的文件 // nodejs 基礎 //storage.js var storage={ set(key,value){ localStorage.setItem(key, JSON.stringify(value)); }, get(key){ return JSON.parse(localStorage.getItem(key)); },remove(key){ localStorage.removeItem(key); } } export default storage;