微信小程序 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]+$/; // 正则表达式,只匹配中文

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

相关推荐
游戏开发爱好者83 小时前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
2501_915106325 小时前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview
2501_915106325 小时前
使用 Sniffmaster TCP 抓包和 Wireshark 网络分析
网络协议·tcp/ip·ios·小程序·uni-app·wireshark·iphone
宠友信息6 小时前
2025社交+IM及时通讯社区APP仿小红书小程序
java·spring boot·小程序·uni-app·web app
“负拾捌”7 小时前
python + uniapp 结合腾讯云实现实时语音识别功能(WebSocket)
python·websocket·微信小程序·uni-app·大模型·腾讯云·语音识别
换日线°1 天前
NFC标签打开微信小程序
前端·微信小程序
光影少年1 天前
AIGC + Taro / 小程序
小程序·aigc·taro
2501_915918411 天前
在 iOS 环境下查看 App 详细信息与文件目录
android·ios·小程序·https·uni-app·iphone·webview
2501_916007471 天前
没有 Mac 用户如何上架 App Store,IPA生成、证书与描述文件管理、跨平台上传
android·macos·ios·小程序·uni-app·iphone·webview
天空属于哈夫克31 天前
Go 语言实战:构建一个企微外部群“技术贴收藏夹”小程序后端
小程序·golang·企业微信