zoukankan      html  css  js  c++  java
  • H5 localstorage本地缓存数据的封装以及在vue中的使用

    vue中常用的 每次增加数据   要缓存

                        每次删除数据也要缓存

     storage.js 文件

    然后某个页面需要本地存储,就需要用 import引入:import storage from './storage.js'

    App.vue页面:

    <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 './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(){                //change事件

        storage.set('list',this.list);  //要缓存
      }

    },

    //获取缓存数据

    mounted(){ /*生命周期函数 vue页面刷新就会触发的方法*/  mounted 生命周期在载入之后就加载数据

      var list=storage.get('list');

      if(list){ /*注意判断*/ 建议先判断缓存的数据存不存在
        this.list=list;

    //或者:this.list=storage.get('list')
      }
    }

    }
    </script>


    <style lang="scss">

    .finish{


    li{
    background:#eee;
    }
    }

    </style>

  • 相关阅读:
    第一次点击button, view视图出现;第二次点击button,view视图消失
    快速破解ps方法
    终端中出现While executing gem ... (Errno::EPERM) Operation not permitted
    隐藏顶部状态栏的方法
    python之dict和set
    python之循环
    python 之条件判断
    python 之列表和元组
    python 之字符串和编码
    人生第一次面试之旅
  • 原文地址:https://www.cnblogs.com/zyyweb/p/9798667.html
Copyright © 2011-2022 走看看