# 用户名-手机号加密特殊处理

# 快速导航

# 用户名-只保留姓氏或中间字符特殊处理

需求:

在做用户信息展示时,只需展示用户名姓,和最后一位,中间一位用*替代

  • 方法 1:封装函数,利用substr截取字符串
点击即可查看
function formatName(name) {
  let newStr;
  if (name.length === 2) {
    newStr = name.substr(0, 1) + '*'; // 通过substr截取字符串从第0位开始截取,截取1个
  } else if (name.length > 2) {
    // 当名字大于2位时
    let char = '';
    for (let i = 0, len = name.length - 2; i < len; i++) {
      // 循环遍历字符串
      char += '*';
    }
    newStr = name.substr(0, 1) + char + name.substr(-1, 1);
  } else {
    newStr = name;
  }

  return newStr;
}
console.log(formatName('王海龙'));
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

输出

王*龙
1
  • 方法 2: 使用正则表达式,只保留姓后面都变为*
点击即可查看详情
var str = '王小明';
var reg = /(?<=.)./g;
result = str.replace(reg, '*');
console.log(result);
1
2
3
4

输出

王**
1

# 手机号码中间 4 位用星号(*)替换显示

在做用户信息展示时,手机号属于私人信息,需要将中间四位给隐藏掉

  • 方法 1: 使用正则表达式
点击即可查看详情
var phone = '13701134148';
var resultPhone = phone.replace(/^(\d{3})\d{4}(\d+)/, '$1****$2');
console.log(resultPhone);
1
2
3

输出

137****4148
1
  • 方法 2: 使用substr方法,字符串截取
点击即可查看详情
var phone = '13701134148';
var mphone = phone.substr(0, 3) + '****' + phone.substr(7);
console.log(mphone);
// 如果用 Es6 模板字符串的话,可以不用+号做拼接
var phone = '13701134148';
var mphone = `${phone.substr(0, 3)}****${phone.substr(7)}`;
1
2
3
4
5
6
移动手机

具体案例体验,可如下小程序码在我的页面体验

移动手机

关注公众号

一个走心,有温度的号,同千万同行一起交流学习

加作者微信

扫二维码 备注 【加群】

扫码易购

福利推荐