Vue中filter过滤器和watch、computed、methods的区别

一、filter

1、filter的作用

filter的作用是:对值进行筛选加工,一般用于格式化输出的场景

2、filter的使用方式

1、双括号插值中

{{ msg | filterA }}双括号插值内,可单个使用也可多个使用
{{ msg | filterA }}单个使用。 {{ msg | filterA| filterB }}多个连用

2、v-bind绑定的值的地方
<h1 v-bind:id=" msg | filterA">{{ msg }}</h1>  //(msg为需要filter处理的值,filterA为过滤器。)

3、 filter的制作方法

new Vue({
    filters:{
    //过滤器一:(使用时没有参数,即{{msg|filterA}})
          filterA(value){
            return “¥”+value
          }
        }
    })
    //添加filters属性,该属性内的函数就是过滤器。其中value就是{{msg|filterA}}中的msg。
new Vue({
    filters:{
    //过滤器二:(使用时有参数,即{{ msg | filterA( arg1, arg2, arg3.... )}})
               filterA (value , ...args){//其中msg为filterA中的第一个参数value。
                for(arg in args{
                  console.log(arg)
                  value+=arg
                }
                return value
              }
        },
           filterB (value , ...args){
                for(arg in args{
                  console.log(arg)
                  value+=arg
                }
                return value
              }
        }
    })
    (使用时有参数,即{{ msg | filterA( arg1, arg2, arg3.... ) | filterB( arg1, arg2, arg3.... )}})
    此时msg为filterA的第一个参数,filterA执行完后的返回值为filterB的第一个参数,以后也是依次类推。

例如:以开发需求为案例,需求是将后端返回的字段付款方式用文字显示:
在这里插入图片描述

1、由于filter中定义的过滤函数不能使用this,需要全局定义一个数组
在这里插入图片描述
2、在vue实例中写filters:{}代码
在这里插入图片描述
全局过滤器
Vue 的全局 API 中提供了注册全局过滤器的函数 Vue.filter(),全局过滤器注册好之后所有的组件可以使用。

<div id="app">
    <input type="text" v-model='msg'>
      <!-- upper 被定义为接收单个参数的过滤器函数,表达式  msg  的值将作为参数传入到函数中 -->
    <div>{{msg | upper}}</div>
    <!--  
      支持级联操作
      upper  被定义为接收单个参数的过滤器函数,表达式msg 的值将作为参数传入到函数中。
	  然后继续调用同样被定义为接收单个参数的过滤器 lower ,将upper 的结果传递到lower中
 	-->
    <div>{{msg | upper | lower}}</div>
    <div :abc='msg | upper'>测试数据</div>
  </div>

<script type="text/javascript">
  //  lower  为全局过滤器     
  Vue.filter('lower', function(val) {
    return val.charAt(0).toLowerCase() + val.slice(1);
  });

  new Vue({
  	el: '#app'
  })
</script>

note: 全局注册时时filter而局部过滤器是filters,局部过滤器注册之后只能在注册的组件内使用

二、watch

watch可以监听某一个数据的变化,watch要想监听对象中某个属性是否发生了变化,需要将deep属性置为true。但是watch无法拿到对象中属性变化的旧值,只能拿到新的对象。

三、computed

computed是计算属性,会监听一个依赖属性,如果这个属性发生变化,就会更新视图,适用于计算比较消耗性能的计算场景,因为其具有缓存功能,这意味着其监听的数据如果没有发生变化,多次调用计算属性会返回之间的计算结果,不必再次执行函数。

四、methods

methods中存放的是事件的回调函数,具有以下几个特点:
1、可以通过Vue实例访问方法,在方法中最好不要使用箭头函数,因为涉及到this指向的问题。
2、重新渲染的时候,methods总会执行该函数。
3、methods是函数调用,filters和computed、watch是属性调用。
4、methods是不具有缓存性的。

五、对比

watch与computed、filter:

watch:监控已有属性,一旦属性发生了改变就去自动调用对应的方法

computed:监控已有的属性,一旦属性的依赖发生了改变,就去自动调用对应的方法

filter:js中为我们提供的一个方法,用来帮助我们对数据进行筛选

watch与computed的区别:

1.watch监控现有的属性,computed通过现有的属性计算出一个新的属性

2.watch不会缓存数据,每次打开页面都会重新加载一次,

但是computed如果之前进行过计算他会将计算的结果缓存,如果再次请求会从缓存中
得到数据(所以computed的性能比watch更好一些)

filter 与 computed 的区别

  1. 触发时机不同

computed 属性背后的处理逻辑比较复杂,依赖 Vue 的数据更新通知机制,在属性所依赖的其他数据项发生变化时才会重新触发计算。优点是计算频率相对较低;缺点是依赖于组件,难以抽取成独立逻辑,也就是复用性低。

filter 则显的简单很多,只在显式调用时触发,一般应用在模板渲染上。优点是容易在组件外抽象;缺点是每次模板渲染时都需要重新执行计算。可以通过示例 感受调用时机的区别:

  1. 应用范围不同

computed 很广泛,可以应用在其他computed、methods、生命周期函数、模板;filter 一般只应用于模板渲染上,如果要在其他位置复用,需要使用 this._f 函数:

Vue.component('HelloWorld', {
 filters: {
 hello() {
 return 'hello';
 }
 },
 methods: {
 ping() {
 return `${this._f('hello')()} world`;
 }
 }
})

另外,在使用上filter支持链式调用,这为其增加了组合拼接的能力:

{{ name | normalize | capitalize }}

  1. 定义方式

最后需要指出,computed 属性只能在组件内部或通过mixins对象定义;而 filter 有两种定义方式,一是在组件内部通过 filters 属性定义;一是在组件外部通过 Vue.filter 函数定义:

Vue.component('HelloWorld', {
 filters: {
 hello() {
 return 'hello';
 }
 }
});
Vue.filter('hello', ()=> 'hello');

应用规则

综上,filter 无法缓存,调用频率高,因此特别适用于格式化输出场景,比如日期格式化。filter 具有组合调用能力,因此可以在项目架构层面定义一堆基础的、简单的filter,按需在组件内组合适用。

computed 属性具有缓存能力,在组件内普适性更强,因此适用于复杂的数据转换、统计等场景。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 当使用Vue.js时,`computed`,`watch`和`methods`都是非常有用的功能。 `computed`属性是一种计算属性,可以根据其依赖关系动态地计算属性值。当它所依赖的属性发生变化时,它会自动重新计算属性值。这使得计算属性非常适合处理动态数据,例如将一组数据进行过滤、排序或计数。 示例代码: ```javascript computed: { // 计算属性,基于 count 和 factor 计算 total total: function () { return this.count * this.factor; } } ``` `watch`属性是一种观察属性,它可以监视Vue实例的属性,并在其发生变化时执行指定的函数。这使得它非常适合处理异步数据,例如通过Ajax请求获取数据。 示例代码: ```javascript watch: { // 监视 message 属性的变化,并在变化时执行 showMessage 函数 message: function (newVal, oldVal) { this.showMessage(newVal); } } ``` `methods`属性是一个方法集合,它包含了Vue实例可用的所有方法。当你需要执行某些特定的操作时,你可以调用其一个方法。 示例代码: ```javascript methods: { // 定义一个 greet 方法 greet: function () { alert('Hello!'); } } ``` 总的来说,`computed`和`watch`适合处理不同类型的数据,而`methods`则是执行特定操作的最佳选择。 ### 回答2: Vue.js是一款MVVM模式的渐进式JavaScript框架。其computedwatchmethodsVue.js非常重要的3个元素,它们分别用于计算、监听数据和存放方法。 1. Computed computed属性可以定义一个计算属性,类似于Vue.js的响应式变量,可以根据依赖数据的变化自动计算得出新的值。computed属性可以使用get和set方法来实现对计算属性的读取和写入操作,在模板该属性会被当做一个正常的属性来处理。 computed适用于需要计算或派生新的值的场景,因为是缓存的,所以可以提升效率。如果依赖的数据没有发生改变,那么计算属性不会重新运行。通常computed适用于重复调用一个函数,但结果又不想重复计算的情况。 2. Watch watch属性是Vue.js用于监听数据变化的方法。它可以监听任何位于data属性的数据变化,当数据变化时,watch会立即执行指定的回调函数。watch可以监听单个变量,也可以监听一个对象或数组,当一个数据集合发生变化时,回调函数只会执行一次,这样可以防止多重操作的影响。 watch适用于需要执行异步操作或需要监听数据变化的场合。watchcomputed运行开销要大,因为它需要在数据发生变化时立刻运行回调函数,这样可能会导致性能问题。通常watch适用于数据变化需要执行比较复杂的操作情况。 3. Methods methods属性是Vue.js存放方法的地方。它们可以在模板通过v-on指令来进行调用。与computed不同的是,methods属性的方法不会自动计算,也不会缓存。每次需要调用方法时,都需要重新运行方法。 methods适用于需要执行一些常规操作、事件的处理、绑定指令等任务。当需要在模板执行复杂操作或有一些逻辑判断时,也可以使用methods。因为methods需要每次都重新计算运行,因此,如果该方法在模板被多次调用,可能会导致性能问题。 综上所述,computedwatchmethodsVue.js各有所长,选择何种方法取决于具体的需求和场景。使用computed可以提升性能,使用watch适用于需要异步处理或监听数据变化的场景,使用methods则适合处理一些常规操作和事件绑定。 ### 回答3: 在 Vue computedwatchmethods 都是非常重要的工具,它们都有自己独特的用途和作用。 Computed Computed 是一种计算属性,基于已有的数据生成新的数据并自动更新,通常用于数据计算,并将结果返回给模板使用。 Computed 应该是纯函数,依赖于数据响应式系统,只有当依赖的数据发生改变时,computed 才会重新计算。 在代码实现computed 的实现方法类似于一个函数,可以使用 get 和 set 语法,也可以简写。 Watch Watch 是数据监听的一种方法,用于监听数据变化并作出相应的操作,可以监听一个或多个属性,当被监听的属性发生变化时,就会触发所声明的函数。 在声明 watch 时,需要指定其监听的数据和回调函数,监听的数据可以是简单类型也可以是复杂类型,当监听的数据属性值发生变化时,watch 回调函数就会被调用,可以在回调函数进行相应的操作。 Methods MethodsVue 实例上定义的方法,可以在模板调用它们完成特定的功能。与 computed 不同的是,methods 方法可以接受参数,通过 this 调用实例上的数据,它们是可变的而 computed 不可变。 方法的代码实现类似于一个函数,可以接受参数,可以调用实例上的数据、方法和其他组件等,并在模板通过方法来执行相应的操作。 在实际开发过程,要灵活选择computedwatchmethods进行数据处理和绑定,根据不同的需求来进行选择使用,以达到高效运行和最佳性能的目的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值