vue2.0已經廢棄了過濾器,需要自定義過濾器,用于一些常見的文本格式化。
成都創(chuàng)新互聯自2013年起,先為清流等服務建站,清流等地企業(yè),進行企業(yè)商務咨詢服務。為清流企業(yè)網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。
感覺超級好用??!
過濾器可以用在兩個地方:雙花括號插值 和 v-bind表達式。
過濾器應該被添加在JavaScript表達式的尾部,由管道符指示。
一、注冊全局過濾器
注意事項:
1、全局方法Vue.filter()注冊一個自定義過濾器,必須放在vue實例化前面
2、過濾器函數始終以表達式的值作為第一個參數,帶引號的參數視為字符串,而不帶引號的參數按表達式計算
3、可以設置兩個過濾器參數,前提這兩個過濾器處理的不沖突
4、用戶從input輸入的數據在會傳到model之前也可以先處理
案例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>過濾器</title> </head> <body> <div id="app"> <!-- 首字符串大寫 --> <div>首字母大寫過濾器:{{str | upcase}}</div> <!-- 給過濾器傳入參數 --> <p>求和過濾器:{{message | sum(10,20)}}</p> </div> <script type="text/javascript" src='https://i0.jrjimg.cn/zqt-red-1000/focus/focus2017YMZ/teamFrighting/js/vue.min.js'></script> <script type="text/javascript"> //全局方法 Vue.filter()注冊一個自定義過濾器,必須放在Vue實例化前面 // 注冊一個首字母大寫的過濾器 Vue.filter("upcase", function(value) { if (!value) return '' value = value.toString() return value.charAt(0).toUpperCase() + value.slice(1) }); // 全局注冊一個求和過濾器 Vue.filter('sum', function (value, a, b) { return value + a + b; }); var demo = new Vue({ el: "#app", data: { str:'hello', message:12 } }); </script> </body> </html>
案例效果:
二、注冊在實例化內部
過濾器也可以注冊在實例內部,僅在使用它的實例里面注冊。
根據以上案例改編:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> <!-- 首字符串大寫 --> <div>首字母大寫過濾器:{{str | upcase}}</div> <!-- 給過濾器傳入參數 --> <p>求和過濾器:{{message | sum(10,20)}}</p> </div> <script type="text/javascript" src='https://i0.jrjimg.cn/zqt-red-1000/focus/focus2017YMZ/teamFrighting/js/vue.min.js'></script> <script type="text/javascript"> var demo = new Vue({ el: "#app", data: { str:'hello', message:12 }, filters: { upcase:function(value){ if (!value) return '' value = value.toString() return value.charAt(0).toUpperCase() + value.slice(1) }, sum:function(value, a, b){ return value + a + b; } } }); </script> </body> </html>
效果:
三、常見過濾器
根據時間戳轉化成時間格式:mm-dd hh:tt
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> <!-- 將時間戳轉化為時間 --> <h2>根據時間戳轉化為時間:{{ str | formateTime}}</h2> </div> <script type="text/javascript" src='https://i0.jrjimg.cn/zqt-red-1000/focus/focus2017YMZ/teamFrighting/js/vue.min.js'></script> <script type="text/javascript"> var demo = new Vue({ el: "#app", data: { str:1517568434324, }, filters: { formateTime:function(nS){ return ((new Date(nS).getMonth()+1)<10?'0'+(new Date(nS).getMonth()+1):(new Date(nS).getMonth()+1)) + '-' + (new Date(nS).getDate()<10?'0'+new Date(nS).getDate():new Date(nS).getDate()) + ' ' + (new Date(nS).getHours()<10?'0'+new Date(nS).getHours():new Date(nS).getHours()) + ':' + (new Date(nS).getMinutes()<10?'0'+new Date(nS).getMinutes():new Date(nS).getMinutes()) } } }); </script> </body> </html>
案例效果:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯。
當前題目:Vue2.0系列之過濾器的使用
URL網址:http://jinyejixie.com/article44/gggghe.html
成都網站建設公司_創(chuàng)新互聯,為您提供網站設計公司、軟件開發(fā)、自適應網站、靜態(tài)網站、移動網站建設、外貿建站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯