vue 過(guò)濾器

過(guò)濾器

  • Vue.js允許自定義過(guò)濾器,可被用于一些常見(jiàn)的文本格式化。
  • 過(guò)濾器可以用在兩個(gè)地方:雙花括號(hào)插值和v-bind表達(dá)式。
  • 過(guò)濾器應(yīng)該被添加在JavaScript表達(dá)式的尾部,由“管道”符號(hào)指示
  • 支持級(jí)聯(lián)操作
  • 過(guò)濾器不改變真正的data,而只是改變渲染的結(jié)果,并返回過(guò)濾后的版本
  • 全局注冊(cè)時(shí)是filter,沒(méi)有s的。而局部過(guò)濾器是filters,是有s的
  <div id="app">
    <input type="text" v-model='msg'>
      <!-- upper 被定義為接收單個(gè)參數(shù)的過(guò)濾器函數(shù),表達(dá)式  msg  的值將作為參數(shù)傳入到函數(shù)中 -->
    <div>{{msg | upper}}</div>
    <!--  
      支持級(jí)聯(lián)操作
      upper  被定義為接收單個(gè)參數(shù)的過(guò)濾器函數(shù),表達(dá)式msg 的值將作為參數(shù)傳入到函數(shù)中。
      然后繼續(xù)調(diào)用同樣被定義為接收單個(gè)參數(shù)的過(guò)濾器 lower ,將upper 的結(jié)果傳遞到lower中
    -->
    <div>{{msg | upper | lower}}</div>
    <div :abc='msg | upper'>測(cè)試數(shù)據(jù)</div>
  </div>

<script type="text/javascript">
   //  lower  為全局過(guò)濾器     
   Vue.filter('lower', function(val) {
      return val.charAt(0).toLowerCase() + val.slice(1);
    });
    var vm = new Vue({
      el: '#app',
      data: {
        msg: ''
      },
       //filters  屬性 定義 和 data 已經(jīng) methods 平級(jí) 
       //  定義filters 中的過(guò)濾器為局部過(guò)濾器 
      filters: {
        //   upper  自定義的過(guò)濾器名字 
        //    upper 被定義為接收單個(gè)參數(shù)的過(guò)濾器函數(shù),表達(dá)式  msg  的值將作為參數(shù)傳入到函數(shù)中
        upper: function(val) {
         //  過(guò)濾器中一定要有返回值 這樣外界使用過(guò)濾器的時(shí)候才能拿到結(jié)果
          return val.charAt(0).toUpperCase() + val.slice(1);
        }
      }
    });
  </script>

過(guò)濾器中傳遞參數(shù)

    <div id="box">
        <!--
            filterA 被定義為接收三個(gè)參數(shù)的過(guò)濾器函數(shù)。
            其中 message 的值作為第一個(gè)參數(shù),
            普通字符串 'arg1' 作為第二個(gè)參數(shù),表達(dá)式 arg2 的值作為第三個(gè)參數(shù)。
        -->
        {{ message | filterA('arg1', 'arg2') }}
    </div>
    <script>
        // 在過(guò)濾器中 第一個(gè)參數(shù) 對(duì)應(yīng)的是  管道符前面的數(shù)據(jù)   n  此時(shí)對(duì)應(yīng) message
        // 第2個(gè)參數(shù)  a 對(duì)應(yīng) 實(shí)參  arg1 字符串
        // 第3個(gè)參數(shù)  b 對(duì)應(yīng) 實(shí)參  arg2 字符串
        Vue.filter('filterA',function(n,a,b){
            if(n<10){
                return n+a;
            }else{
                return n+b;
            }
        });
        
        new Vue({
            el:"#box",
            data:{
                message: "哈哈哈"
            }
        })

    </script>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容