Vue自定義指令實現(xiàn)對數(shù)字進行千分位分隔
說在前面
對數(shù)字進行千分位分隔后展示應該是大部分同學都做過的功能了吧,常規(guī)的做法通常是編寫一個工具函數(shù)來對數(shù)據(jù)進行轉換,那么我們可不可以通過vue指令
來實現(xiàn)這一功能呢?
效果展示
實現(xiàn)原理
非輸入框
非輸入框我們只需要對其展示進行處理,我們可以判斷綁定元素的innerHTML
是否不為空,不為空的話則直接對其innerHTML
內容進行格式化。
export default { bind: function (el, binding) { const separator = binding.value || ","; if (el.innerHTML) { el.innerHTML = addThousandSeparator(el.innerText, separator); } }, };
輸入框
對于輸入框,我們希望其有以下功能:
1、輸入的時候去掉分隔符
這里我們只需要監(jiān)聽元素的聚焦(focus)
事件即可,取到元素的值,將其分隔符去掉后重新賦值。
el.addEventListener("focus", (event) => { const value = event.target.value; event.target.value = deleteThousandSeparator(value, separator); });
2、輸入完成后添加分隔符
這里我們只需要監(jiān)聽元素的失焦(blur)
事件即可,取到元素的值,對其進行添加分隔符處理后重新賦值。
el.addEventListener("blur", (event) => { const value = event.target.value; event.target.value = addThousandSeparator(value, separator); });
千分位分隔函數(shù)
function addThousandSeparator(num, separator = ",") { return num.toString().replace(/\B(?=(\d{3})+(?!\d))/g, separator); }
num.toString(): 將輸入的數(shù)字 num 轉換為字符串,以便后續(xù)處理。
.replace(/\B(?=(\d{3})+(?!\d))/g, separator): 這里使用了正則表達式進行替換操作。具體解釋如下:
- \B: 表示非單詞邊界,用于匹配不在單詞邊界處的位置。
- (?=(\d{3})+(?!\d)): 使用正向預查來匹配每三位數(shù)字的位置,但不匹配末尾不足三位的數(shù)字。
- (\d{3})+: 匹配連續(xù)的三位數(shù)字。
- separator: 作為參數(shù)傳入的分隔符,默認為 ,。
- g: 表示全局匹配,即匹配所有滿足條件的位置。
這樣,通過正則表達式的替換功能,在數(shù)字字符串中的每三位數(shù)字之間插入指定的千位分隔符,從而實現(xiàn)千位分隔符的添加。
去掉千分位分隔
function deleteThousandSeparator(numberString, separator = ",") { return numberString.replace(new RegExp(separator, "g"), ""); }
直接將字符串中的分隔符全部替換為空即可。
完整代碼
function addThousandSeparator(num, separator = ",") { return num.toString().replace(/\B(?=(\d{3})+(?!\d))/g, separator); } function deleteThousandSeparator(numberString, separator = ",") { return numberString.replace(new RegExp(separator, "g"), ""); } export default { bind: function (el, binding) { const separator = binding.value || ","; if (el.innerHTML) { el.innerHTML = addThousandSeparator(el.innerText, separator); } el.addEventListener("focus", (event) => { const value = event.target.value; event.target.value = deleteThousandSeparator(value, separator); }); el.addEventListener("blur", (event) => { const value = event.target.value; event.target.value = addThousandSeparator(value, separator); }); }, };
組件庫
組件文檔
目前該組件也已經(jīng)收錄到我的組件庫,組件文檔地址如下:http://jyeontu.xyz/jvuewheel/#/JThousandView
組件內容
組件庫中還有許多好玩有趣的組件,如:
- 懸浮按鈕
- 評論組件
- 詞云
- 瀑布流照片容器
- 視頻動態(tài)封面
- 3D輪播圖
- web桌寵
- 貢獻度面板
- 拖拽上傳
- 自動補全輸入框
- 圖片滑塊驗證
等等……
組件庫源碼
組件庫已開源到gitee,有興趣的也可以到這里看看:https://gitee.com/zheng_yongtao/jyeontu-component-warehouse
以上就是Vue自定義指令實現(xiàn)對數(shù)字進行千分位分隔的詳細內容,更多關于Vue數(shù)字千位分隔的資料請關注腳本之家其它相關文章!
相關文章
element中el-autocomplete的常見用法示例
這篇文章主要給大家介紹了關于element中el-autocomplete的常見用法的相關資料,文中通過實例代碼介紹的非常詳細,對大家學習或者使用element具有一定的參考學習價值,需要的朋友可以參考下2023-03-03vue2前端使用axios發(fā)起post請求后端(springboot)接收不到值解決辦法
這篇文章主要介紹了vue2前端使用axios發(fā)起post請求后端(springboot)接收不到值解決辦法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2024-03-03使用elementUI實現(xiàn)將圖片上傳到本地的示例
今天小編就為大家分享一篇使用elementUI實現(xiàn)將圖片上傳到本地的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09vue 集成 vis-network 實現(xiàn)網(wǎng)絡拓撲圖的方法
這篇文章主要介紹了vue 集成 vis-network 實現(xiàn)網(wǎng)絡拓撲圖的方法,本文通過實例代碼給大家介紹的非常詳細 ,需要的朋友可以參考下2019-08-08