vue过滤器(filter)

vue中可以自定义过滤器,用于{{插槽}}和v-bind表达式。

// 双花括号插槽
{{ message | capitalize }}

// v-bind
  • 全局定义
    (1) 全局方法 Vue.filter() 注册一个自定义过滤器,必须放在Vue实例化前面
    (2) 过滤器函数始终以表达式的值作为第一个参数。带引号的参数视为字符串,而不带引号的参数按表达式计算
Vue.filter('filterA', value => {
  if (!value) return ''
  value = value.toString()
  return value.replace(
          value.substr(1, value.length - 1),
          '*'.repeat(value.length - 2)
        ) + value.substr(-1, 1)
})
Vue.filter("change", {
     read(value) { 
        return value;
     },
    write(newVal,oldVal) { 
        console.log("newVal:"+newVal); 
        console.log("oldVal:"+oldVal);
        return newVal;
   }
});
new Vue({
  // ...
})


    
        
        vue自定义过滤器
        
        
    
    
        

{{message | sum}}

{{message | cal 10 20}}

{{message | sum | currency }}

  • 局部注册filter
filters: {
    license (value) {
      return (
        value.replace(
          value.substr(1, value.length - 1),
          '*'.repeat(value.length - 2)
        ) + value.substr(-1, 1)
      )
    },
  },
  • 串联过滤器
{{ message | filterA | filterB }}

filterA 被定义为接收单个参数的过滤器函数,表达式 message 的值将作为参数传入到函数中。然后继续调用同样被定义为接收单个参数的过滤器函数 filterB,将 filterA 的结果传递到 filterB 中。

你可能感兴趣的:(vue过滤器(filter))