[vue]經過watch實現數據雙向綁定

modal:單向綁定

<head>
    <meta charset="UTF-8">
    <title>test</title>
    <style>
        .mask {
            width: 100%;
            height: 100%;
            position: fixed;
            background: rgba(0, 0, 0, .35);
            top: 0;
            left: 0
        }

        .dialog {
            width: 400px;
            height: 150px;
            background: #fff;
            position: fixed;
            top: 50%;
            left: 50%;
            transform: translate3d(-50%, -50%, 0)
        }
    </style>
</head>
<body>
<div id="app">
    <button @click="flag=true">click</button>
    <mymodal :childflag="flag" @childthings="()=>flag=false"></mymodal>
</div>
<template id="dialog">
    <div class="mask" v-show="childflag">
        <div class="dialog">
            <button @click="shutdown">關閉</button>
        </div>
    </div>
</template>
<script src="node_modules/vue/dist/vue.js"></script>
<script>
  let vm = new Vue({
    el: "#app",
    data: {
      flag: false,
    },
    components: {
      mymodal: {
        props: ['childflag'],
        template: "#dialog",
        methods: {
          shutdown() {
            this.$emit('childthings')
          }
        }
      },
    }
  })
</script>

modal:雙向綁定

<head>
    <meta charset="UTF-8">
    <title>modal</title>
    <style>
        .mask {
            width: 100%;
            height: 100%;
            position: fixed;
            background: rgba(0, 0, 0, .35);
            top: 0;
            left: 0
        }

        .dialog {
            width: 400px;
            height: 150px;
            background: #fff;
            position: fixed;
            top: 50%;
            left: 50%;
            transform: translate3d(-50%, -50%, 0)
        }
    </style>
</head>
<body>
<div id="app">
    <modal :childflag="flag" @childthings="things"></modal>
    <button @click="open">open</button>
</div>

<template id="dialog">
    <div class="mask" v-show="mychildflag">
        <div class="dialog">
            <button @click="childclose">close</button>
        </div>
    </div>
</template>
<script src="node_modules/vue/dist/vue.js"></script>
<script>
  let vm = new Vue({
    el: "#app",
    data: {
      msg: "maotai",
      flag: false,
    },
    methods: {
      open() {
        this.flag = true;
      },
      things(val) {
        this.flag = val;
      }
    },
    components: {
      modal: {
        props: ['childflag'],
        data() {
          return {
            mychildflag: this.childflag,
          }
        },
        watch: {
          childflag(val) {
            this.mychildflag = val;
          },
          mychildflag(val) {
            this.$emit('childthings', val)
          }
        },
        methods: {
          childclose() {
            this.mychildflag = !this.mychildflag;
          }
        },
        template: "#dialog"
      }
    }
  })
</script>

雙向綁定解釋

<div id="app">
    <switchbtn :result="result" @on-result-change="onResultChange"></switchbtn>
    <input type="button" value="change" @click="change">
</div>

<script src="node_modules/vue/dist/vue.js"></script>
<script>
  Vue.component("switchbtn", {
    props: ["result"],
    data: function () {
      return {
        myResult: this.result//①建立props屬性result的副本--myResult
      };
    },
    watch: {
      result(val) {
        this.myResult = val;//②監聽外部對props屬性result的變動,並同步到組件內的data屬性myResult中
      },
      myResult(val) {
        this.$emit("on-result-change", val);//③組件內對myResult變動後向外部發送事件通知
      }
    },
    methods: {
      change() {
        this.myResult = !this.myResult;
      }
    },
    template: "<div @click='change'>{{myResult?'開':'關'}}</div>"
  });

  let vm = new Vue({
    el: "#app",
    data: {
      result: true
    },
    methods: {
      change() {
        this.result = !this.result;
      },
      onResultChange(val) {
        this.result = val;//④外層調用組件方註冊變動方法,將組件內的數據變動,同步到組件外的數據狀態中
      }
    }
  });
</script>
相關文章
相關標籤/搜索