当前位置: 首页 > news >正文

正则魔法:解码 return /^\d+$/.test(text) ? text : ‘0‘ 的秘密

🚀 正则魔法:解码 return /^\d+$/.test(text) ? text : '0' 的秘密 🌟

嘿,技术探险家们!👋 今天我们要破解一段看似简单的代码:return /^\d+$/.test(text) ? text : '0'。它藏在一个 Vue 前端组件中,与后端的分页查询接口息息相关。这篇文章将带你深入剖析它的作用,结合前后端交互,揭开正则表达式的“魔法”!还有流程图助阵,快跟我一起探索吧!💪


🎯 第一幕:代码的“藏身之处”

问题起源

我在调试一个邀请码管理页面(invite-code-list.vue),发现前端向后端发送分页请求时,有个方法让我眼前一亮:

private getAllowInviteValue(text: string): string {
    const map: { [key: string]: string } = {
        '不允许': '0',
        '允许1级': '1',
        '允许2级': '2',
        '允许不限层级': '127',
        '允许不限': '127'
    }
    const value = map[text]
    if (value) {
        return value
    }
    // 如果输入的是数字,直接返回
    return /^\d+$/.test(text) ? text : '0'
}

这段代码出现在 fetchInviteCodeList 中,当搜索字段是 allowInvite 时,它会处理搜索值。咦?这个正则表达式和三元运算符是干嘛的?🤔


🔍 第二幕:正则与逻辑的解密

代码分析

让我们拆解 return /^\d+$/.test(text) ? text : '0'

  • /^\d+$/
    • 这是一个正则表达式:
      • ^:字符串开头。
      • \d:匹配任意数字(0-9)。
      • +:匹配一个或多个数字。
      • $:字符串结尾。
    • 含义:检查 text 是否是纯数字字符串(如 "123"),不含字母、空格或其他字符。
  • .test(text)
    • 测试 text 是否符合正则规则,返回 truefalse
  • ?:
    • 三元运算符:条件 ? 值1 : 值2
    • 如果 ^\d+$/.test(text)true,返回 text;否则返回 '0'
完整逻辑

结合整个方法:

  1. 映射表检查
    • 如果 text'不允许''允许1级' 等,返回对应的数字(如 '0''1')。
  2. 正则兜底
    • 如果 text 不在映射表中:
      • 检查是否是纯数字(如 '123'),如果是,直接返回。
      • 否则,返回默认值 '0'
示例
  • text = '不允许' → 返回 '0'(映射表匹配)。
  • text = '3' → 返回 '3'(正则是数字)。
  • text = 'abc' → 返回 '0'(非数字)。
  • text = '' → 返回 '0'(空字符串)。

🐞 第三幕:它在前端的作用

上下文:邀请码搜索

fetchInviteCodeList 中:

private async fetchInviteCodeList() {
    const { page, size, field, value } = this.listQuery
    let searchValue = value
    if (field === 'allowInvite' && value) {
        searchValue = this.getAllowInviteValue(value)
    }
    const params = { page, size, field, value: searchValue }
    const response = await getInviteCodeListByInvitor(params)
    // ... 处理响应 ...
}
  • 场景
    • 用户在搜索框输入 value,选择 fieldallowInvite(转邀请)。
    • getAllowInviteValue 将输入转换为后端能识别的数字。
  • 目的
    • 后端期望 allowInvite 是数字(如 0 表示不允许,1 表示允许1级)。
    • 前端通过映射表和正则,确保 value 是有效数字。
Mermaid 流程图:搜索值转换
用户输入: value='允许1级'
field='allowInvite'
getAllowInviteValue
在映射表中?
返回 '1'
是纯数字?
返回 text
返回 '0'
发送请求: value='1'

🔧 第四幕:前后端交互的桥梁

后端视角

后端接口(假设):

@PostMapping("/listInviteCodeByPageWithSearch")
public BaseResult listInviteCodeByPageWithSearch(@RequestBody PageWithSearch pageWithSearch) {
    // ... 处理 pageWithSearch ...
}

PageWithSearch

public class PageWithSearch extends BasePage {
    private String field;
    private String value;
    // ... 其他字段 ...
}
  • 前端参数
    • listQuery 中的 fieldvalue 直接映射到 PageWithSearch
  • 后端处理
    • 如果 field='allowInvite'value 应该是数字字符串(如 '0''1')。
    • 服务层可能将 value 转为 Integer 或直接用于查询。

为什么需要这个转换?

  • 数据一致性
    • 后端数据库中 allowInvite 可能存储为 int(如 01127)。
    • 前端输入可能是文字(如 '允许1级')或数字(如 '3')。
  • 容错性
    • 用户可能输入非法值(如 'abc'),getAllowInviteValue 保证返回有效默认值 '0'

🌈 第五幕:经验与反思

学到了啥?💡

  1. 正则的妙用
    • /^\d+$/ 简洁高效,确保输入是纯数字。
  2. 前后端协作
    • 前端提前转换数据,减轻后端负担。
  3. 容错设计
    • 映射表 + 正则兜底,处理各种输入场景。

小建议 🌟

  • 前端校验
    • 加个输入提示,告诉用户 allowInvite 支持哪些值。
    if (field === 'allowInvite' && !/^\d+$/.test(value) && !map[value]) {
        this.$message.warning('转邀请请输入数字或有效选项');
    }
    
  • 后端验证
    • PageWithSearch 中加校验:
      @Pattern(regexp = "^\\d+$", message = "转邀请值必须是数字")
      private String value;
      

🎬 尾声

return /^\d+$/.test(text) ? text : '0' 到前后端交互的桥梁,这段代码虽小,却承载了数据转换的重任。它让我对正则表达式和容错设计有了新认识。希望这篇博客能帮你在开发中更好地处理类似场景!有问题欢迎留言,咱们一起聊技术!✌️

在这里插入图片描述

相关文章:

  • 【笔记】深度学习模型训练的 GPU 内存优化之旅:重计算篇
  • 2025最新电脑IP地址修改方法:Win系统详细步骤
  • springboot使用163发送自定义html格式的邮件
  • 为什么TCP需要三次握手?一次不行吗?
  • 【Servlet 容器和 Spring 容器的关系】
  • 人工智能之数学基础:线性方程组
  • mysql-innodb存储引擎主键索引叶子结点数据结构(非单纯的双向链表)
  • PyCharm安装redis,python安装redis,PyCharm使用失败问题
  • WPF 布局舍入(WPF 边框模糊 或 像素错位 的问题)
  • Datawhale coze-ai-assistant 笔记4
  • 16 预编译指令
  • 再学:ERC20-Permit2、SafeERC20方法 详解ERC721,如何铸造一个NFT以及IPFS的作用
  • 进程控制~
  • 【宇宙回响】从Canvas到MySQL:飞机大战的全栈交响曲【附演示视频与源码】
  • 普通鼠标的500连击的工具来了!!!
  • 【MySQL】MySQL登录,访问,退出操作
  • 微软Data Formulator:用AI重塑数据可视化的未来
  • 突破时空边界:Java实时流处理中窗口操作与时间语义的深度重构
  • 图解AUTOSAR_CP_DIODriver
  • 从头开始学C语言第二十八天——字符指针和字符串
  • 北京公园使用指南
  • 春暖花开,为何皮肤却闹起了小情绪?
  • 美大学建“私人联盟”对抗政府:学校已存在300年,特朗普才上任3个月
  • 从 “沪惠保” 到 “沪骑保”看普惠保险的 “上海样式”
  • 多地征集农村假冒伪劣食品违法线索,全链条整治“三无”产品
  • 特朗普承认“24小时结束俄乌冲突”是玩笑:大家都知道