身份证号脱敏的正确实现

Uni-app / Vue 中身份证号脱敏的正确实现

一、业务背景说明

在医疗、政务、金融等小程序场景中,身份证号属于强隐私数据。常见的产品要求是:

  • 页面展示时 不能明文显示完整身份证号
  • 通常规则为:前 6 位 + 后 4 位可见,中间用 * 替代
  • 点击、提交、接口交互时仍使用原始完整数据

因此,前端的核心任务只有一个:

展示层脱敏,不影响原始数据结构

本文基于你当前的 uni-app + Vue2 项目,不做任何封装,只讲清楚「为什么错」「应该怎么写」「每种写法适合什么场景」。


二、最容易犯的错误

错误 1:直接在模板里对非字符串使用 slice

vue 复制代码
{{ doctor.id_card_no.slice(0,6) }}
问题原因
  • 后端返回的 id_card_no 可能是 number
  • slice 只存在于 String / Array

运行时就会报错:

复制代码
TypeError: e.slice is not a function

错误 2:把"带参数的函数"写进 computed

js 复制代码
computed: {
  maskIdCard(id) {
    return id.slice(0,6) + '****' + id.slice(-4)
  }
}

模板中使用:

vue 复制代码
{{ maskIdCard(item.id_card_no) }}
问题原因(非常关键)
  • computed 不是函数工具区
  • computed 本质是:基于响应式状态的属性
  • Vue 不会把它当成 methods 处理

最终就会报错:

复制代码
TypeError: e.maskIdCard is not a function

三、正确做法一:methods(最推荐、最直观)

methods 中定义脱敏函数

js 复制代码
methods: {
  maskIdCard(id) {
    // 1. 空值保护
    if (id === null || id === undefined) return '';

    // 2. 强制转字符串(关键)
    const str = String(id);

    // 3. 长度不足直接返回
    if (str.length <= 8) return str;

    // 4. 身份证标准脱敏规则
    return (
      str.slice(0, 6) +
      '*'.repeat(str.length - 10) +
      str.slice(-4)
    );
  }
}

模板中直接调用

vue 复制代码
<view class="name1">
  {{ maskIdCard(doctor.id_card_no) }}
</view>

优点

  • 写法直观,符合直觉
  • 支持传参
  • 不依赖响应式缓存
  • 非常适合「工具函数」

结论:带参数的展示逻辑 = methods


四、正确做法二:computed(仅限"当前就诊人")

如果页面只展示 一个固定对象 (例如 selectedPatient),可以用 computed。

computed 写法

js 复制代码
computed: {
  maskedIdCard() {
    const id = this.selectedPatient?.id_card_no;
    if (!id) return '';

    const str = String(id);
    if (str.length <= 8) return str;

    return (
      str.slice(0, 6) +
      '*'.repeat(str.length - 10) +
      str.slice(-4)
    );
  }
}

模板使用

vue 复制代码
<view class="name1">
  {{ maskedIdCard }}
</view>

限制说明

  • 不能传参
  • 不适合列表
  • 只适合「单对象展示」

五、列表场景为什么一定要用 methods

真实场景:

vue 复制代码
<pationsCard
  v-for="item in pationsList"
  :cardId="maskIdCard(item.id_card_no)"
/>

原因只有一句话:

computed 不能根据不同 item 动态计算

列表中:

  • 每一项都是不同身份证号
  • 每次渲染都需要传参

只能用 methods


六、最终推荐规范(非常重要)

场景 正确位置
列表身份证脱敏 methods
单个当前用户展示 computed
传参的展示逻辑 methods
工具型字符串处理 methods

七、一句话总结

在 Vue / Uni-app 中,computed 用于"状态派生值"methods 用于"带参数的展示逻辑" 。身份证号脱敏本质是字符串处理工具函数,在列表与组件参数中使用时,只能也必须写在 methods 中

相关推荐
2501_920931701 天前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
0思必得01 天前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5161 天前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino1 天前
图片、文件的预览
前端·javascript
2501_920931701 天前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05281 天前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔1 天前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李1 天前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN1 天前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒1 天前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局