千分位分隔?一个 vue 指令搞定
说在前面
🎈对数字进行千分位分隔后展示应该是大部分同学都做过的功能了吧,常规的做法通常是编写一个工具函数来对数据进行转换,那么我们可不可以通过
vue指令
来实现这一功能呢?
效果展示
实现原理
非输入框
非输入框我们只需要对其展示进行处理,我们可以判断绑定元素的innerHTML
是否不为空,不为空的话则直接对其innerHTML
内容进行格式化。
输入框
对于输入框,我们希望其有以下功能:
1、输入的时候去掉分隔符
这里我们只需要监听元素的聚焦(focus)
事件即可,取到元素的值,将其分隔符去掉后重新赋值。
2、输入完成后添加分隔符
这里我们只需要监听元素的失焦(blur)
事件即可,取到元素的值,对其进行添加分隔符处理后重新赋值。
千分位分隔函数
num.toString(): 将输入的数字 num 转换为字符串,以便后续处理。
.replace(/\B(?=(\d{3})+(?!\d))/g, separator): 这里使用了正则表达式进行替换操作。具体解释如下:
\B: 表示非单词边界,用于匹配不在单词边界处的位置。
(?=(\d{3})+(?!\d)): 使用正向预查来匹配每三位数字的位置,但不匹配末尾不足三位的数字。
(\d{3})+: 匹配连续的三位数字。
separator: 作为参数传入的分隔符,默认为 ,。
g: 表示全局匹配,即匹配所有满足条件的位置。
这样,通过正则表达式的替换功能,在数字字符串中的每三位数字之间插入指定的千位分隔符,从而实现千位分隔符的添加。
去掉千分位分隔
直接将字符串中的分隔符全部替换为空即可。
完整代码
组件库
组件文档
目前该组件也已经收录到我的组件库,组件文档地址如下:http://jyeontu.xyz/jvuewheel/#/JThousandView
组件内容
组件库中还有许多好玩有趣的组件,如:
悬浮按钮
评论组件
词云
瀑布流照片容器
视频动态封面
3D 轮播图
web 桌宠
贡献度面板
拖拽上传
自动补全输入框
图片滑块验证
等等……
组件库源码
组件库已开源到 gitee,有兴趣的也可以到这里看看:https://gitee.com/zheng_yongtao/jyeontu-component-warehouse
觉得有帮助的可以点个 star~
有什么问题或错误可以指出,欢迎 pr~
有什么想要实现的组件或想法可以联系我~
公众号
关注公众号『前端也能这么有趣
』,获取更多有趣内容。
发送『组件库
』获取源码
说在后面
🎉 这里是 JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球 🏸 ,平时也喜欢写些东西,既为自己记录 📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解 🙇,写错的地方望指出,定会认真改进 😊,偶尔也会在自己的公众号『
前端也能这么有趣
』发一些比较有趣的文章,有兴趣的也可以关注下。在此谢谢大家的支持,我们下文再见 🙌。
版权声明: 本文为 InfoQ 作者【JYeontu】的原创文章。
原文链接:【http://xie.infoq.cn/article/9a0c91a994b61af730ebf7690】。文章转载请联系作者。
评论