小程序js(正则表达式):文本框对手机号进行标准化规范

这篇具有很好参考价值的文章主要介绍了小程序js(正则表达式):文本框对手机号进行标准化规范。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、使用 <input> 组件的 type 属性设置为 "number",并结合正则表达式进行校验。

<input type="number" bindinput="checkPhoneNumber" />
Page({
  checkPhoneNumber: function (e) {
    const phoneNumber = e.detail.value;
    // 正则表达式校验手机号格式
    if (!/^1[3456789]\d{9}$/.test(phoneNumber)) {
      // 手机号格式不正确,提示用户
      wx.showToast({
        title: '请输入正确的手机号',
        icon: 'none'
      });
    }
  }
});

 

/^1[3456789]\d{9}$/ 是一个正则表达式,用于匹配手机号码的格式。

具体解释如下:

  • / 是正则表达式的开始和结束标记。
  • ^ 表示匹配字符串的开头。
  • 1 表示要匹配的字符串必须以数字 1 开头。
  • [3456789] 表示下一位的数字必须是 3、4、5、6、7、8 或 9 中的一个。
  • \d 表示匹配任意数字。
  • {9} 表示前面的模式 \d 必须重复匹配 9 次,即匹配 9 个数字。
  • $ 表示匹配字符串的结尾。

综合起来,/^1[3456789]\d{9}$/ 匹配以数字 1 开头,接着是 3、4、5、6、7、8 或 9 中的一个,然后是 9 个数字,最后以字符串结尾的字符串,符合这个格式的字符串就可以被认为是一个手机号码。

因此,当我们使用 if (!/^1[3456789]\d{9}$/.test(phoneNumber)) 这样的条件判断时,如果 phoneNumber 不符合这个正则表达式的格式,即不是一个正确的手机号码,条件判断将会返回 true,进入条件判断的代码块,执行相应的提示或处理逻辑。

 二、使用 <input> 组件的 type 属性设置为 "text",并在 bindinput 事件中过滤非数字字符,并判断手机号长度是否合法。

<input type="text" bindinput="filterPhoneNumber" />
Page({
  filterPhoneNumber: function (e) {
    let phoneNumber = e.detail.value;
    // 过滤非数字字符
    phoneNumber = phoneNumber.replace(/\D/g, '');
    // 判断手机号长度是否合法
    if (phoneNumber.length > 11) {
      phoneNumber = phoneNumber.substr(0, 11);
    }
    // 更新输入框的值
    this.setData({ phoneNumber });
  }
});

 文章来源地址https://www.toymoban.com/news/detail-755028.html

到了这里,关于小程序js(正则表达式):文本框对手机号进行标准化规范的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 正则表达式与文本处理器

    文本处理器三剑客:grep(查找) sed  awk 正则表达式: 由一类特殊字符以及文本字符所编写的一种模式,处理文本当中的内容 其中的一些字符不表示字符的字面含义,这些字符表示控制或者通配的功能 通配符: 匹配文件名和目录名,不能匹配文件内容 正则表达式有两种匹

    2024年02月16日
    浏览(49)
  • 文本三剑客&正则表达式2

    主要是对文件内容按照行的方式进行增删改查 工作流程 sed的工作流程主要包括** 读取、执行和显示 **三个过程 读取 sed从 输入流 (文件、管道、标准输入) 中读取一行内容并存储到临时的缓冲区中(又称模式空间,pattern space ) 执行 默认情况下,所有的sed命令都在模式空间中

    2024年02月05日
    浏览(46)
  • Linux文本处理工具和正则表达式

    Linux文本处理工具和正则表达式 cat 最常用的文件查看命令;当不指明文件或者文件名为一杠’-\\\'时,读取标准输入。 more 默认将多行文本满屏输出,只允许向文本末尾翻页(空格键满屏翻页;回车键单行翻页),阅读到文末自动退出。 用法 一般使用管道传给more来阅读内容超过

    2024年02月13日
    浏览(71)
  • 2.1 python文本处理-正则表达式

    标准库模块 re 模块方法 # 将正则表达式样式编译成一个正则对象。一般用于多次使用正则对象的场景 re.compile( pattern ) # 扫描string字符串并查找符合patten样式的第一个位置,返回对应的 Match 结果,否则返回 None re.search(patten, string) # 如果  string  开头的零个或多个字符与正则

    2024年02月01日
    浏览(57)
  • Python 正则表达式:强大的文本处理工具

    正则表达式是一种强大的文本匹配和处理工具,它可以用来在字符串中查找、替换和提取符合某种规则的内容。在Python中,使用re模块可以轻松地操作正则表达式,它提供了丰富的功能和灵活的语法。 正则表达式在许多场景中都非常有用。以下是一些常见的应用场景: 数据清

    2024年02月09日
    浏览(56)
  • 正则表达式和文本三剑客题型练习

    ​ 1、显示/etc/passwd文件中以bash结尾的行; 解释:使用 grep 工具来搜索文件 /etc/passwd 中匹配模式 \\\'bash$\\\' 的行。 bash$ 是一个正则表达式,其中 $ 表示行结尾。因此, \\\'bash$\\\' 匹配以 bash 结尾的行。 运行结果: ​ 2、找出\\\"netstat  -tan”命令的结果中,以‘LISTEN’后跟0或多个空白字

    2024年02月06日
    浏览(43)
  • 正则表达式与正则可视化工具:解密文本处理的利器

    在计算机科学和软件开发领域,正则表达式是一种强大而灵活的文本处理工具。然而,对于初学者来说,正则表达式的语法和规则可能会显得晦涩难懂。为了帮助初学者更好地理解和学习正则表达式,正则可视化工具应运而生。本文将介绍正则表达式的基本概念、语法和应用

    2024年02月19日
    浏览(53)
  • 使用正则表达式替换文本中的html标签

    我们存储 markdown 文章时,如果存储转换后的 html 页面,那么在查出来的时候,会带有标签,可以使用正则表达式去除标签 如果要展示 html 文本,肯定不能直接删除掉标签,如下即可:

    2024年02月13日
    浏览(45)
  • js 正则表达式

    不允许汉字  state.rulesForm.username = value.replace(/[u4e00-u9fa5]/gi, \\\"\\\"); 只允许数字和字母 state.rulesForm.username = value.replace(/[^a-zA-Z0-9]+/g, \\\"\\\"); 只允许数字 state.rulesForm.qlmId = value.replace(/[^0-9]/g, \\\"\\\"); 只允许数字和字母和符号 this.form.username = this.form.username.replace(/[^a-zA-Z0-9@#$%^*()._+=?-,]+/g,

    2024年02月08日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包