美文网首页
vue双向数据绑定

vue双向数据绑定

作者: 事在人为s | 来源:发表于2018-12-27 21:25 被阅读0次

App.vue

<template>
  <div id="app">
    <input type="text" v-model="todo" v-on:keydown="keydown($event)">
    <button v-on:click="add">新增</button>
    <br>
    <h2>未完成</h2>
    <ul>
      <li v-for="(item,key) in list" v-if="!item.check">
        <input type="checkbox" v-model="item.check" v-on:change="saveList()">
        {{item}} --------
        <button v-on:click="remove(key)">删除</button>
      </li>
    </ul>
    <br>
    <h2>已完成</h2>
    <ul>
      <li v-for="(item,key) in list" v-if="item.check">
        <input type="checkbox" v-model="item.check" v-on:change="saveList()">
        <input type="checkbox">
        {{item}} --------
        <button v-on:click="remove(key)">删除</button>
      </li>
    </ul>
  </div>
</template>

<script>
import storage from "./model/storage.js";

export default {
  name: "app",
  data() {
    return {
      todo: "",
      list: []
    };
  },
  methods: {
    add() {
      this.list.push({
        text: this.todo,
        check: false
      });
      this.todo = "";
      storage.set("list", this.list);
      //localStorage.setItem("list", JSON.stringify(this.list));
    },
    remove(key) {
      this.list.splice(key, 1);
      storage.set("list", this.list);
      //localStorage.setItem("list", JSON.stringify(this.list));
    },
    keydown(e) {
      if (e.keyCode == 13) {
        this.list.push({
          text: this.todo,
          check: false
        });
        this.todo = "";
        storage.set("list", this.list);
        //localStorage.setItem("list", JSON.stringify(this.list));
      }
    },
    saveList() {
      storage.set("list", this.list);
    }
  },
  mounted() {
    //var list = JSON.parse(localStorage.getItem("list"));
    var list = storage.get("list");
    if (list) {
      this.list = list;
    }
  }
};
</script>

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; 

相关文章

  • Vue 中的双向数据绑定

    双向绑定 单向数据流 双向绑定 or 单向数据流 Vue 是单向数据流,不是双向绑定 Vue 的双向绑定是语法糖 ...

  • Vue入门(二)——数据绑定

    一、什么是双向数据绑定 双向数据绑定是Vue的核心功能之一。所谓双向数据绑定是指:HTML标签上的数据绑定到Vue...

  • vue 双向数据绑定

    Vue实现数据双向绑定的原理:Object.defineProperty()vue实现数据双向绑定主要是:采用数据...

  • 深入Vue响应式原理

    1.Vue的双向数据绑定 参考 vue的双向绑定原理及实现Vue双向绑定的实现原理Object.definepro...

  • 02Vue.js的数据绑定

    理解Vue的双向数据绑定 Vue有一个显著的地方就是它拥有双向数据绑定功能,那么何为双向数据绑定呢?双向是指:HT...

  • Vue实现数据双向绑定的原理

    Vue实现数据双向绑定的原理:Object.defineProperty() vue实现数据双向绑定主要是:采用数...

  • 02Vue.js快速入门-Vue入门之数据绑定

    2.1. 什么是双向绑定? Vue框架很核心的功能就是双向的数据绑定。 双向是指:HTML标签数据 绑定到 Vue...

  • 如何用js手动实现一个数据双向绑定

    双向数据绑定: 我们这里拿vue举例,vue中的双向数据绑定主要是利用Object.defineProperty(...

  • Vue之表单双向数据绑定和组件

    三、表单双向数据绑定和组件 目录:双向数据绑定、组件 1.双向数据绑定 1)什么是双向数据绑定Vue.js是一个M...

  • vue基本面试题总结

    原文地址:vue基本面试题 1、vue双向数据绑定? vue数据双向绑定是通过 数据劫持 结合 发布者-订阅者 模...

网友评论

      本文标题:vue双向数据绑定

      本文链接:https://www.haomeiwen.com/subject/mladlqtx.html