vue2 - 计算属性

  <div id="root">
    性:<input type="text" v-model:value="firstName"><br>
    名:<input type="text" v-model:value="lastName"><br>
    全名:<span>{{fullName}}</span>
  </div>

  <script>
    const vm=new Vue({
      el: "#root",
      data: {
        firstName: "张",
        lastName: "三"
      },
      //计算属性
      computed: {
        fullName: {
          //当有人读取fullName时,get就会被调用,且返回值就作为fullName的值
          //get有缓存,一个页面多次调用时,只会读取一次,但数据发生改变时,页面会重新读取数据
          get(){
            console.log("get被调用了");
            return this.firstName+"-"+this.lastName;
          },
          //当数据(fullName)被修改时,set会被调用
          set(value){
            console.log("set被调用了");
            var array=value.split("-");
            this.firstName=array[0];
            this.lastName=array[1];
          }
        }
      }
    });
  </script>

简写(计算属性一般用于读取):

      computed: {
        fullName(){
          return this.firstName+"-"+this.lastName;
        }
      }

 

posted on 2022-04-28 14:53  每天积极向上  阅读(346)  评论(0编辑  收藏  举报

导航