sau交流学习社区—vue总结:使用vue的computed属性实现监控变量变化,使用vue的watch属性监控变量变化从而实现其他业务...

编程入门 行业动态 更新时间:2024-10-07 02:19:37

sau交流学习社区—vue总结:使用vue的computed属性实现监控<a href=https://www.elefans.com/category/jswz/34/1771380.html style=变量变化,使用vue的watch属性监控变量变化从而实现其他业务..."/>

sau交流学习社区—vue总结:使用vue的computed属性实现监控变量变化,使用vue的watch属性监控变量变化从而实现其他业务...

有时候遇到这么个需求,输入框为空的时候,请求一遍接口,如果输入框不为空的时候,需要点击搜索按钮请求接口。

同步sau交流学习社区:/page/464.html

 

一、使用computed属性的实时监控计算

我第一反应是做一个computed属性监控这个输入框的值,一旦监控发现值为空,我就重新执行一遍请求的方法。

<el-col :xs="8" :sm="8" :md="4" :lg="4" :xl="4"><el-input v-model="searchContent" placeholder="请输入相关内容"></el-input>
</el-col>
<el-col :xs="8" :sm="8" :md="4" :lg="4" :xl="4"><el-button @click="search()" type="primary">搜索</el-button></el-col>
  
 data () {return {searchContent: ''}},
 
 computed: {searchContent: function () {if(!this.searchContent){this.getEventCategories();}}},
 

查找资料发现:1、计算属性也是属性,把他当做普通属性,所以你在computed中定义searchContent属性,在data中再次定义searchContent就会爆出重复定义的问题。

 

当我在data中不定义searchContent时候,

发现超出了浏览器栈最大的允许的大小,说明什么呢,就是说,你陷入了无限循环,栈溢出了,发现就是计算属性里有计算属性本身,循环计算这个属性。

这时候自己才想起来,2、computed属性就是一个普通属性,唯一区别不同的地方就是:computed属性里的function里的任何数据发生变化都会触发这个属性值的计算。

 

二、使用watch方法来实现检测值的变化并且需要调用其他方法

最后自己只能使用watch方法来实现这个功能

  watch: {"searchContent": function () {if(!this.searchContent){this.getEventCategories();}}},

这个时候在data里还是需要定义searchContent这个变量,意思就是说,检测searchContent的值变化,一旦发现这个值为空的时候就调用method的方法getEventCategories()。否则就不会调用这个方法。

 

最后上一张动态图

 

三、总结

1、computed属性的结果会被缓存,依赖的属性如果发生变化才会重新计算,把他当做普通属性来使用;

2、watch属性,主要用来监听某些特定数据的变化,从而进行某些具体的业务逻辑操作,可以把他看作是computed和methods的结合体;

3、methods方法表示一个具体的操作,主要书写业务逻辑;

 

转载于:.html

更多推荐

sau交流学习社区—vue总结:使用vue的computed属性实现监控变量变化,使用vue的watch属性监控变量变化从而实现其他业务...

本文发布于:2024-03-15 11:06:12,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1738758.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:变量   属性   业务   社区   sau

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!