今天在改写应用的前端页面时发现个问题:关键字段都未进行脱敏处理,于是乎准备使用vue管道符“|”对其进行脱敏,在输入框后加上管道符后报错“Uncaught TypeError: Cannot read property ‘read’ of undefined”,

如下图所示:
在这里插入图片描述

刚开始以为是未引入vue.min.js的问题,但是后来发现是因为在定义了管道符后为进行过滤器的增加!
解决方法:
在我们methods方法后面增加一个filter过滤器,对v-model中的值进行处理即可完成脱敏操做;

filters: {
				idCard: function (value) {
					if (!value) return ''
					//return value.replace(/(\w{3})\w*(\w{4})/, '$1******$2')
					return value.replace(/(\w{1})\w*(\w{1})/, '$1****************$2')

				},
				phone: function (value) {
					if (!value) return ''
					return value.replace(/(\w{1})\w*(\w{2})/, '$1********$2')
				},
				name: function (value) {
					if (!value) return ''
					else {
						if (value.length == 3) {
							return value.substr(0, 1) + "**"
						} else if (value.length == 2) {
							return value.substr(0, 1) + "*"
						} else {
							return value.substr(0, 1) + "***"
						}

					}
				}
			}
Logo

前往低代码交流专区

更多推荐