微信小程序 input 不能输入特殊字符的方法

微信小程序开发中经常遇到有表单提交的需求,一些特殊的字段要过滤掉特殊字符。比如姓名、籍贯、地址等,都要实现不能输入特殊字符的功能,可以创建一个统一的方法来处理输入事件,并在这个方法中检查输入的字符。

下面是一个简单的示例:

html 复制代码
<view class='flex f30 ali-center'>
          <input type="text" name="realname" value='{{realname}}' placeholder="请填真实姓名" bindchange="onName" data-field="realname" />
</view>
<view class='flex f30 ali-center'>
          <input type="text" name="hometown" value='{{hometown}}' placeholder="请填写籍贯" bindchange="onName" data-field="realname" />
</view>
<view class='flex f30 ali-center'>
          <input type="text" name="address" value='{{address}}' placeholder="请填写地址" bindchange="onName" data-field="address" />
</view>

js:

js 复制代码
// 输入框发生改变事件
onField(e) {
    let value = e.detail.value;
    let field = e.currentTarget.dataset.field
    // console.log('Input field:', field, 'Value:', value); 
    this.handleSpecialChars(value, field)
},

// 过滤特殊字符
handleSpecialChars(value, fieldName) {     
    let reg = /^[\u4e00-\u9fa5a-zA-Z0-9\s,.?!;:\'"]+$/; // 允许中文字符、英文字母、数字以及基本标点符号 
    if (!reg.test(value)) {  
      wx.showToast({  
        title: '不能输入特殊字符',  
        icon: 'none'  
      });
      this.setData({  
        [fieldName]: ''  
      }); 
    } else {
      this.setData({  
        [fieldName]: value  
      });  
      return value; 
    }
},

如果姓名更严格点可以限制只允许输入中文:

js 复制代码
let reg = /^[\u4e00-\u9fa5]+$/; // 正则表达式,只匹配中文

请注意,这个示例在输入非符合正则表达式时会清空输入框,这可能会影响到部分用户的体验感。

相关推荐
毕设源码-朱学姐10 小时前
【开题答辩全过程】以 基于微信小程序的大学生安全素质综合培养平台设计与实现为例,包含答辩的问题和答案
微信小程序·小程序
潆润千川科技13 小时前
中老年垂直社交小程序产品功能对比与设计思路分析
小程序
木风未来13 小时前
解锁自然新可能:露营租赁小程序如何让轻量化户外触手可及
小程序
木风未来16 小时前
破解家政维修信任困局:一个小程序如何让家庭服务更透明、更高效
小程序
Java.慈祥18 小时前
速通-微信小程序 5Day
java·微信小程序·小程序·npm
说私域19 小时前
数字围城下的防御与突围:基于私域流量与智能名片商城小程序的用户关系重构研究
小程序·重构·流量运营·私域运营
未来之窗软件服务19 小时前
服务器运维(三十四)小程序web访问慢ssl优化—东方仙盟
运维·服务器·小程序·仙盟创梦ide·东方仙盟
全栈小520 小时前
【小程序】微信小程序slice方法分割无效,单独输出一直为空,这是为什么呢
微信小程序·小程序·数组分割
Light6020 小时前
心智有效性测试小程序 V1.0 产品白皮书——心智结构量化与系统稳定性评估平台
小程序·apache
予你@。20 小时前
uni-app(Vue3)实现自定义 Tab 切换滑块效果(微信小程序)
vue.js·微信小程序·uni-app