前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ts 限制输入框只能输入一个 emoji 表情

ts 限制输入框只能输入一个 emoji 表情

作者头像
饶文津
发布2021-12-06 12:30:56
8510
发布2021-12-06 12:30:56
举报
文章被收录于专栏:饶文津的专栏饶文津的专栏

我们知道 emoji 的长度不定,可以是两个字符,还可以是多个字符。它是用 unicode 编码的。所以我们不能直接利用长度来截取字符串中第一个 emoji。

比较方便的方法是借助 lodash 库的 toArray 函数。

它里面每个 emoji 就是长度为 1。

安装

代码语言:javascript
复制
npm i lodash.toarray

代码

代码语言:javascript
复制
import toArray = require("lodash.toarray");

const getFirstEmoji = (value: string) : string => {
  if (!value) {
    return "";
  }
  let strarr = toArray(value);
  return strarr.slice(0, 1)[0];
}

输入框的 input 回调上里调用这个函数即可。

这样返回的是第一个字符或者第一个 emoji。我的需求就是这样的。但如果你想排除普通字符,那么需要对字符串具体值进行判断是否在表情包的 unicode 范围内,网上的大部分范围都不全,或许可以看看lodash源码。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-12-03 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装
  • 代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档