实现VUE input新增输入时用户敏感信息脱敏

本文介绍如何在Vue中实现用户输入敏感信息(如姓名、身份证号、手机号)时实时脱敏,采用双input元素策略,区分展示值与真实值。通过混入mixin实现公共的脱敏方法,并利用事件监听处理用户输入,确保在提交时能传递真实数据给后端。
摘要由CSDN通过智能技术生成

近日接到需要输入用户信息的同时进行信息脱敏的需求,平时的脱敏只在展示时用到过,边输入边脱敏,本小白直接蒙了。难点在于,vue动态绑定的值不能脱敏后传给后端,需要传输客户填写的真实数据。研究一番最后决定采用“双input框”方法,通过区分展示值和真实值的方式,让接口传真实值,而页面展示脱敏后的数据。

第一部分 脱敏JS方法

这里利用了vue的mixin混入策略,将脱敏的方法写成公共的,方便其他模块公用。

export const mixins = {
    //身份证脱敏
	methods: {
   
	//身份证号脱敏
		setCertNo(certNo) {
   
			if (certNo && certNo.length >= 10) {
   
				var certNo = certNo.trim();
				// let cert1 = certNo.substring(0, certNo.length-4);
				// let cert2 = cert1 + "****";
				// return cert2;
				// let cert1 = certNo.replace(/(\w{6})\w{2}(\w{6})\w{4}/, '$1**$2****');
				let cert1 = certNo.substring(0, 6) + '**' + certNo.substring(8, certNo.length - 4) + '****';
				return cert1;
			}else{
   
				return certNo;
			}
		},
		//手机脱敏
		setTel(tel) {
   
			if (tel && tel.length >= 11) {
   
				var pat = /(\d{3})\d*(\d{4})/
				let telFinal = tel.replace(pat, '$1****$2');
				return telFinal
			}else{
   
				return tel;
			}
		},
		//脱敏姓名 方式一,根据性别变成某女士或者某先生
		setName(str, sex) {
   
			if (str && sex) {
   
			  let str1 = str.substr(0, 1);
			  
  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您是在 Vue 中使用 Ant Design 的 Input 和 Select 组件来实现输入展示多个选项的效果,可以参考以下步骤: 1. 在 Vue 组件中引入 Ant Design 的 Input 和 Select 组件。 ```vue <template> <div> <a-input-search :enter-button="true" @search="handleSearch"> <a-select slot="suffix" v-model="value" :options="options" @change="handleSelect" show-search placeholder="请选择" > <a-select-option v-for="option in options" :key="option.value" :value="option.value" > {{ option.label }} </a-select-option> </a-select> </a-input-search> </div> </template> <script> import { Input, Select } from 'ant-design-vue'; export default { name: 'MultiSelectInput', components: { 'a-input-search': Input.Search, 'a-select': Select, 'a-select-option': Select.Option, }, data() { return { options: [], value: '', }; }, methods: { handleSearch(value) { // 根据输入内容获取选项数据 const options = getOptions(value); this.options = options; }, handleSelect(value) { // 将选项的值填充到输入框中 this.value = value; }, }, }; </script> ``` 在上面的示例代码中,我们在 Vue 组件中引入了 Ant Design 的 Input 和 Select 组件,并且使用了 Input.Search 和 Select 组件结合的方式来实现输入展示多个选项的效果。当用户输入内容后,我们通过调用 handleSearch 方法来获取选项数据,并且将 options 属性设置为获取到的选项数据。当用户选择某个选项后,我们通过调用 handleSelect 方法来将选项的值填充到输入框中。 需要注意的是,上面的示例代码中使用了 Ant Design Vue 中的组件,因此需要先安装并引入 Ant Design Vue 库。另外,示例中的 getOptions 方法需要根据具体的业务逻辑实现,用于根据输入内容获取选项数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值