1. 数据绑定
首先 demo 中是建立了一个一维数组存放了几个手机号, 然后以此一位数组为数据来源进行循环创建, for 容器下的文本组件进行了数据绑定, 并且在当前数据 1 后面加入了一些函数方法. 这里使用的都是 JavaScript 的函数方法和语法.(要使用 JS 方法需要用数据绑定的模式)
2. 正则表达式
正则表达式是对字符串操作的一种逻辑公式, 就是用事先定义好的一些特定字符, 及这些特定字符的组合, 组成一个 "规则字符串", 这个 "规则字符串" 用来表达对字符串的一种过滤逻辑. 正则表达式本身功能是十分强大的, 但是要想特别熟练使用也需要很多练习. 有一句话是说, 当你要用正则表达式解决一个问题的时候, 那你现在就拥有两个问题了. 这里只简单介绍一下 demo 中的代码含义, 对此感兴趣朋友可以自己去详细学习一下正则表达式.
当前数据 1 是一个字符串对象, 这里是用了 replace() 方法, 可以理解为括号中 "," 后面双引号中的内容来替代两个 "/" 之间的内容, g 表示执行全局匹配, 即查找所有匹配而非在找到第一个匹配后停止."/" 之间的内容可以分为三部分,^(\d{3}),\d{4},(\d{4})$."^" 匹配输入字符串开始的位置,"$" 匹配输入字符串结尾的位置,\d 表示查找数字,{3} 表示查找的数字位数. 所以这里就是把手机号分成了开头三位, 中间四位和结尾四位三个部分. 逗号后面双引号里面的内容,$1 代表的是 (\d{3}),$2 代表的是 (\d{4}), 这里是使用了正则表达式中的捕捉组, 捕获组就是把正则表达式中子表达式匹配的内容, 保存到内存中以数字编号或显式命名的组里方便后面引用, 只有加了括号括起来的部分才能被捕捉到 (具体的捕捉组编号命名规则及引用可以上网查阅资料). 这样最后就完成了保留前三位和后四位这两个部分, 并把中间换成, 拼接出了最终结果.
3.substr() 方法
下面再说一种比较简单的方法, 就是使用 substr(), 就是从原字符串中截取一段子字符串. 方法里只有两个数字参数, 前面的代表起始位置, 后面的是子字符串的长度. 详细描述可以参考下图.
例如 demo 中的手机号 "13245876647", 从左到右位置序号是 0-12, 我们要实现 demo 中的效果可以如下写, 最终效果是一样的. 第一部分是截取了手机号的前三位, 第二部分是 "" 字符串, 第三部分就是手机号的后四位. 这里要注意的是如果是数据绑定的变量是不需要加双引号的, 如果是自己输入的内容是需要加双引号的, 而且必须是英文的双引号, 最后用加号把各部分连接起来就可以了.
4.slice() 方法
同时还有一种方法也可以选择, 就是 slice() 方法, 与 substr() 方法对比可以发现区别在于 substr() 方法的参数指定的是起始位置和长度, 而 slice() 方法的参数指定的直接是起始和终止位置.
所以还可以写成下图模式 (注意截取的字符串包含起始位置, 但是不包含终止位置所以填 (0,3))
5.substring() 方法
与 slice() 方法相似的还有一种 substring() 方法. 与 slice() 方法不同的是虽然他的参数也是起始和终止坐标, 但是他是不接受负数作为参数的, 而且如果不小心将终止坐标填的比起始坐标还要小, 那么方法在执行前会将两个参数调换, 如果起始坐标和终止坐标相等, 那么就会返回空的字符串.
使用 substring() 方法达成 demo 中的效果如图. 注意同 slice() 方法一样截取的字符串包含起始位置, 但是不包含终止位置所以填 (0,3)
6.split() 方法
再分享一种比较常用到的方法吧, 就是 split() 方法. 比如数据库中的提交时间是 "2020-03-16 15:37:36", 我们可能前台展示的时候只希望展示年月日, 而省去时分秒.
这时可以进行如下数据绑定..split("")[0] 就是将原字符串按双引号内的字符串进行分割, 这里就是一个空格的空字符串, 分割成了两个元素,[0] 就是提取分割出来的数组元素的第一个元素, 如果填写 split(" ")[1] 则获取的是时分秒.
7. 大小写转换 toLowerCase() 和 toUpperCase()
最后补充一个大小写转换的方法吧, 使用也很简单, 就以转换小写举一个例子啦. 这样进行数据绑定就可以把文本变量中的所有小写英文字母都转换成大写.
8. 总结
对字符串的格式化处理方法是多种多样的, 大家也可以自己探索新的办法. ivx 本身也保持了可以和一些函数方法联合使用的接口, 而且有专门的函数组件, 在一些小细节的处理上还是很方便的. 知识果然还是越多越全面才好呀!
来源: http://www.bubuko.com/infodetail-3465124.html