四、Vue计算属性与监听属性

Vue计算属性与监听属性

Vue.JS计算属性

关键词:computed
作用:处理一些复杂逻辑时很有用
例子:反转字符串

<div id="app">
  <p>原始字符串: {{ message }}</p>
  <p>计算后反转字符串: {{ reversedMessage }}</p>  //如果没用计算属性则应该是Message.split('').reverse().join('')
</div>
 
<script>
var vm = new Vue({
  el: '#app',
  data: {
    message: 'Runoob!'
  },
  computed: {   //computed声明了一个计算属性reversedMessage
    // 计算属性的 getter,提供的函数将用作属性 vm.reversedMessage 的 getter 
    reversedMessage: function () {
      // `this` 指向 vm 实例
      return this.message.split('').reverse().join('')
      //mv.reversedMessage依赖于mv.Message,在mv.Message发生变化时,mv.reversedMessage也会更新
    }
  }
})
</script>

computed与methods
两者本效果上是一样的,可以相互代替。

区别:
(1)computed是基于他的依赖缓存 ,只有相关依赖发生改变时才会重新取值。
methods在重新渲染的时候,函数纵湖重新调用执行。
(2)获取computed声明的属性的值:{{ 属性名 }}
例子:{{reversedMEssage}}
获取methods函数的值:{{ 函数名() }}
例子:{{reversedMessage()}}
(3)使用computed性能会更好,但如果不希望缓存,可以使用methods属性

<div id="app">
  <p>原始字符串: {{ message }}</p>
  <p>计算后反转字符串: {{ reversedMessage }}</p>
  <p>使用方法后反转字符串: {{ reversedMessage2() }}</p>   //与computed的区别
</div>
<script>
var vm = new Vue({
  el: '#app',
  data: {
    message: 'Runoob!'
  },
  computed: {
    // 计算属性的 getter
    reversedMessage: function () {
      // `this` 指向 vm 实例
      return this.message.split('').reverse().join('')
    }
  },
  methods: {
    reversedMessage2: function () {
      return this.message.split('').reverse().join('')
    }
  }
})
</script>

computed的setter
computed属性的默认值是getter,但在需要的时候可以停工一个setter

<div id="app">
  <p>{{ site }}</p>
</div>
var vm = new Vue({
  el: '#app',
  data: {
    name: 'Google',
    url: 'http://www.google.com'
  },
  computed: {
    site: {
      // getter
      get: function () {
        return this.name + ' ' + this.url
      },
      // setter
      set: function (newValue) {
        var names = newValue.split(' ')   //以空格进行分割,形成字符串数组,与split('')是有区别的
        this.name = names[0]
        this.url = names[names.length - 1]
      }
    }
  }
})
// 运行vm.site是会调用 setter, vm.name 和 vm.url 也会被对应更新
vm.site = '菜鸟教程 http://www.runoob.com';
document.write('name: ' + vm.name);
document.write('<br>');
document.write('url: ' + vm.url);

运行结果:
在这里插入图片描述

Vue.js监听属性

vue.js的监听属性watch,可以通过watch来响应数据的变化
实例:通过watch实现计数器

<div id = "app">
    <p style = "font-size:25px;">计数器: {{ counter }}</p>
    <button @click = "counter++" style = "font-size:25px;">点我</button>  //v-on监听事件,监听“点击按钮,后自加”,进行响应
</div>
<script type = "text/javascript">
var vm = new Vue({
    el: '#app',
    data: {
        counter: 1
    }
});
vm.$watch('counter', function(nval, oval) {  //监听,响应数据变化
    alert('计数器值的变化 :' + oval + ' 变为 ' + nval + '!');
});
</script>

监听属性格式:

vm.$watch('变量名',function(参数1,参数2){  
//参数1数据变量数据改变前的值,参数2是变量数据改变后的值
	//响应数据
});

例子:千米和米之间进行换算

<div id = "computed_props">
    千米 : <input type = "text" v-model = "kilometers">: <input type = "text" v-model = "meters">
</div>
<p id="info"></p>
<script type = "text/javascript">
    var vm = new Vue({
    el: '#computed_props',
    data: {
        kilometers : 0,
        meters:0
    },
    methods: {
    },
    computed :{
    },
    watch : {
        kilometers:function(val) {
            this.kilometers = val;
            this.meters = this.kilometers * 1000
        },
        meters : function (val) {
            this.kilometers = val/ 1000;
            this.meters = val;
        }
    }
    });
    // $watch 是一个实例方法
    vm.$watch('kilometers', function (newValue, oldValue) {
    // 这个回调将在 vm.kilometers 改变后调用
    document.getElementById ("info").innerHTML = "修改前值为: " + oldValue + ",修改后值为: " + newValue;
})
</script>

运行结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值