今天在改写应用的前端页面时发现个问题:关键字段都未进行脱敏处理,于是乎准备使用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) + "***"
}
}
}
}