如何使用 js 过滤文本框表情符号

问题产生背景

在做某一后台管理项目时,由于发送请求时,若用户在文本框输入表情符号,提交的数据在插入数据库会报错,因此需要前后端对,用户输入的文本框的值进行校验;此篇文章只分享前端如何进行表单校验;
如下图所示:
在这里插入图片描述

解决办法

由于产品要求项目中的所有文本框都需要进行 emoji 限制,因此我封装了一个工具函数,作为表单的自定义校验规则,封装的工具函数代码如下,大家可以直接使用:

// 判断文本中是否有表情
const isEmojiCharacter = (substring: any) => {
  if(substring?.length > 0){
    for ( var i = 0; i < substring.length; i++) {
      var hs = substring.charCodeAt(i);
      if (0xd800 <= hs && hs <= 0xdbff) {
          if (substring.length > 1) {
              var ls = substring.charCodeAt(i + 1);
              var uc = ((hs - 0xd800) * 0x400) + (ls - 0xdc00) + 0x10000;
              if (0x1d000 <= uc && uc <= 0x1f77f) {
                  return true;
              }
          }
      } else if (substring.length > 1) {
          var ls = substring.charCodeAt(i + 1);
          if (ls == 0x20e3) {
              return true;
          }
      } else {
          if (0x2100 <= hs && hs <= 0x27ff) {
              return true;
          } else if (0x2B05 <= hs && hs <= 0x2b07) {
              return true;
          } else if (0x2934 <= hs && hs <= 0x2935) {
              return true;
          } else if (0x3297 <= hs && hs <= 0x3299) {
              return true;
          } else if (hs == 0xa9 || hs == 0xae || hs == 0x303d || hs == 0x3030
                  || hs == 0x2b55 || hs == 0x2b1c || hs == 0x2b1b
                  || hs == 0x2b50) {
              return true;
          }
      }
    }
  }
}

以上函数接收一个文本框的值,若文本框有表情就返回 true , 在实际项目中我们可以根据 Form.Item 的 rules 属性自定义校验规则,代码如下:

<Form.Item rules={[{
              validator: (_, value) => {
                const isEmoji = isEmojiCharacter(value)
                console.log('12123' , isEmoji)
                return !isEmoji ? Promise.resolve() : Promise.reject(new Error('不允许输入表情符号'))
              },
              validateTrigger: 'onChange'
          }]} label="接口名称" style={{ marginLeft: 20 }} name="interName">
              <Input allowClear placeholder="请输入接口名称" />
</Form.Item>

至此便可以实现了前端文本框emoji 的校验~~

写在最后

以上提供的方法,便是解决校验文本框表情符号的方法,但是仍然存在部分表情不能校验的问题,如若有完全的表情校验方法,欢迎评论区留言交流;

🥂(❁´◡`❁)您的点赞👍➕评论📝➕收藏⭐是作者创作的最大动力🤞

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端小二哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值