vue过滤器(filter)

2019-12-18  本文已影响0人  北风吹_yfy

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

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

// v-bind
<div v-bind:id="rawId | formatId"></div>
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({
  // ...
})
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>vue自定义过滤器</title>
        <script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
        <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
    </head>
    <body>
        <div class="test">
            <p>{{message | sum}}</p>
            <p>{{message | cal 10 20}}</p>  <!--过滤器函数始终以表达式的值作为第一个参数。带引号的参数视为字符串,而不带引号的参数按表达式计算。-->
            <p>{{message | sum | currency }}</p> <!--添加两个过滤器,注意不要冲突-->
 
            <input type="text" v-model="message | change"> <!--用户从input输入的数据在回传到model之前也可以先处理-->
 
        </div>
        <script type="text/javascript">
            Vue.filter("change", {
                read: function (value) { // model -> view 在更新 `<input>` 元素之前格式化值
                    return value;
                },
                write: function (newVal,oldVal) { // view -> model  在写回数据之前格式化值
                    console.log("newVal:"+newVal); 
                    console.log("oldVal:"+oldVal);
                    return newVal;
                }
            });
 
            var myVue = new Vue({
                el: ".test",
                data: {
                    message:12
                },
                filters: {
                    sum: function (value) {
                        return value + 4;
                    },
                    cal: function (value, begin, xing) {
                        return value + begin + xing;
                    }
                }
            });
 
        </script>
    </body>
</html>
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 中。

上一篇 下一篇

猜你喜欢

热点阅读