Vue2.0系列之過濾器的使用
vue2.0已經(jīng)廢棄了過濾器,需要自定義過濾器,用于一些常見的文本格式化。
感覺超級好用??!
過濾器可以用在兩個地方:雙花括號插值 和 v-bind表達式。
過濾器應該被添加在JavaScript表達式的尾部,由管道符指示。
一、注冊全局過濾器
注意事項:
1、全局方法Vue.filter()注冊一個自定義過濾器,必須放在vue實例化前面
2、過濾器函數(shù)始終以表達式的值作為第一個參數(shù),帶引號的參數(shù)視為字符串,而不帶引號的參數(shù)按表達式計算
3、可以設置兩個過濾器參數(shù),前提這兩個過濾器處理的不沖突
4、用戶從input輸入的數(shù)據(jù)在會傳到model之前也可以先處理
案例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>過濾器</title> </head> <body> <div id="app"> <!-- 首字符串大寫 --> <div>首字母大寫過濾器:{{str | upcase}}</div> <!-- 給過濾器傳入?yún)?shù) --> <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>
案例效果:
二、注冊在實例化內部
過濾器也可以注冊在實例內部,僅在使用它的實例里面注冊。
根據(jù)以上案例改編:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> <!-- 首字符串大寫 --> <div>首字母大寫過濾器:{{str | upcase}}</div> <!-- 給過濾器傳入?yún)?shù) --> <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>
效果:
三、常見過濾器
根據(jù)時間戳轉化成時間格式:mm-dd hh:tt
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <div id="app"> <!-- 將時間戳轉化為時間 --> <h1>根據(jù)時間戳轉化為時間:{{ str | formateTime}}</h1> </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>
案例效果:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
利用vue + element實現(xiàn)表格分頁和前端搜索的方法
眾所周知Element 是一套 Vue.js 后臺組件庫,它能夠幫助你更輕松更快速地開發(fā)后臺項目。下面這篇文章主要給大家介紹了關于利用vue + element實現(xiàn)表格分頁和前端搜索的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-12-12Vue中Layout內部布局el-row、el-col的實現(xiàn)
layout是一種非常方便的布局方式,本文主要介紹了Vue中Layout內部布局el-row、el-col的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-07-07vue 實現(xiàn)websocket發(fā)送消息并實時接收消息
這篇文章主要介紹了vue 實現(xiàn)websocket發(fā)送消息并實時接收消息,項目結合vue腳手架和websocket來搭建,本文給大家分享實例代碼,需要的朋友可以參考下2019-12-12Vue使用html2canvas實現(xiàn)截取圖片并保存
html2canvas是一個JavaScript庫,它可以將HTML元素轉換為Canvas元素本文將介紹一下Vue如何使用html2canvas實現(xiàn)截取圖片并保存功能,需要的可以參考下2023-12-12vue 路由視圖 router-view嵌套跳轉的實現(xiàn)
這篇文章主要介紹了vue 路由視圖 router-view嵌套跳轉,主要實現(xiàn)的內容有制作一個登錄頁面,跳轉到首頁,首頁包含菜單欄、頂部導航欄、主體,標準的后臺網(wǎng)頁格式,菜單點擊顯示不同的頁面,感興趣的小伙伴請參考下面文章內容2021-09-09vuex + keep-alive實現(xiàn)tab標簽頁面緩存功能
這篇文章主要介紹了vuex + keep-alive實現(xiàn)tab標簽頁面緩存功能,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-10-10vue項目實現(xiàn)一鍵網(wǎng)站換膚效果實例(webpack-theme-color-replacer的使用)
換皮膚一般都是點擊一個按鈕彈出一些皮膚的選項,選中選項后皮膚生效,下面這篇文章主要給大家介紹了關于vue項目實現(xiàn)一鍵網(wǎng)站換膚效果的相關資料,文中主要介紹的是webpack-theme-color-replacer的使用,需要的朋友可以參考下2023-02-02Vue3組合式API中使用forwardRef()函數(shù)
本文主要介紹了Vue3組合式API中使用forwardRef()函數(shù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-06-06