前端解决表情符号乱码问题(前端处理表情符号编码)@令狐张豪

本文介绍了在前端项目中遇到的一个问题,即用户输入的Unicode表情在MySQL数据库中显示为???。原因是MySQL的utf8编码不支持四字节的Emoji。为了解决这个问题,作者提供了两个JavaScript方法,用于编码和解码表情符号。通过在插入数据前对表情进行编码,并在获取数据后解码,成功解决了表情显示问题。这是一个针对前端开发中字符编码问题的实战解决方案。
摘要由CSDN通过智能技术生成

今天接手了一个项目,里面有个功能点是点赞评论的功能,之前写的代码用户输入表情符号后我们返显出来的是一堆???问号

  • 大概原因:UTF-8编码有可能是两个、三个、四个字节。Emoji表情是4个字节,而Mysql的utf8编码最多3个字节,所以数据插不进去,识别不出来就成了一堆???。
  • 解决方案:先把用户选择的表情符号用charCodeAt给转成编码,取数据时再解码成16进制的就好了。

这里直接封装好的两个js方法,粘贴复制直接调用就行

		//编码:
        emojiEncode(e) {
            var n = /[\ud800-\udbff][\udc00-\udfff]/g;
            // 检测utf16字符正则
            return e = e.replace(n, function(e) {
                var n, r;
                return 2 === e.length ? (n = e.charCodeAt(0), r = e.charCodeAt(1),
                    "&#" + (1024 * (n - 55296) + 65536 + r - 56320) + ";") : e
            })
        },
		//解码:
        emojiDecode(e) {
            var n = /\&#.*?;/g; //获取数据库种16进制的数据
            //然后进行解码操作
            return e.replace(n, function(e) {
                var n, r, t;
                return 9 == e.length ? (t = parseInt(e.match(/[0-9]+/g)), n = Math.floor((t - 65536) / 1024) + 55296, r = (t - 65536) % 1024 + 56320, unescape("%u" + n.toString(16) + "%u" + r.toString(16))) : e
            })
        },



			//我们输入了评论内容把内容进行编码
     		var data = {
                   token: App.getP('token'),
                   family_content_id: App.getP('family_content_id'),
                   comment_message: this.emojiEncode(this.commentMessage)
              }
           //获取数据后在解码
             content: {
                   text: that.emojiDecode(that.commentMessage),
                   date: "刚刚"
              },
                
                

end~~~

如有错误或观点不一致的请评论留言共同讨论,本人前端小白一枚,根据自己实际项目遇到的问题进行总结分享,谢谢大家的阅读!
文章对您有所帮助请给作者点个赞支持下,谢谢~

### 回答1: 这是一个命令行指令,其中 "D:\Anaconda3\python.exe" 是 Python 解释器的路径,"C:\Users\张豪\Desktop\pythonProject\111.py" 是你要运行的 Python 脚本的路径,"C:\Users\张豪\Desktop\pythonProject" 是你的工作路径。这个命令会运行你的 Python 脚本,并将工作路径设置为 "C:\Users\张豪\Desktop\pythonProject"。如果你想要在 Python 脚本中使用这个工作路径,你可以使用以下代码: ```python import os print(os.getcwd()) ``` 这将打印出工作路径 "C:\Users\张豪\Desktop\pythonProject"。 ### 回答2: D:\Anaconda3\python.exe是Anaconda中Python解释器的路径,C:\Users\张豪\Desktop\pythonProject\111.py是要运行的Python脚本的路径,C:\Users\张豪\Desktop\pythonProject是该脚本所在的文件夹路径。 该命令表示使用Anaconda中的python.exe来运行111.py这个脚本,在运行时需要提供111.py所在的完整路径。 C:\Users\张豪\Desktop\pythonProject是脚本所在的文件夹路径,通过将此路径作为参数传递给111.py脚本,脚本可以在相应的文件夹中读取或写入文件。 总之,通过输入以上命令,可以在命令行界面中执行python脚本111.py,并在C:\Users\张豪\Desktop\pythonProject文件夹中进行相关操作。 ### 回答3: D:\Anaconda3\python.exe 是Anaconda环境下的Python解释器的路径,通过这个路径可以执行Python脚本。 C:\Users\张豪\Desktop\pythonProject\111.py 是待执行的Python脚本的路径和文件名,通过执行这个脚本可以运行其中的Python代码。 C:\Users\张豪\Desktop\pythonProject 是Python脚本所在的工作目录,通过设置这个目录可以作为Python脚本执行的基准目录,方便调用其他文件或者指定文件的输出位置。 总结来说,该命令表示使用Anaconda环境下的Python解释器来执行C:\Users\张豪\Desktop\pythonProject\111.py文件,并将C:\Users\张豪\Desktop\pythonProject设置为执行的工作目录,以便于Python脚本的运行。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值