本文主要是介绍前端处理过滤,特殊字符以及输入法特殊表情符号emoji的正则方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
问题描述
输入法输入表情或特殊符号,存入数据库时,会发现有报错,因为UTF-8编码有可能是两个、三个、四个字节。Emoji表情是4个字节,而MySQL的utf8编码最多3个字节,所以数据插不进去。
解决方法
前端处理方法
思路使用正则匹配特殊符号或表情进行过滤,如下(根据自己的需求调整):
// 使用正则检查输入值是否包含表情符号 checkEmoji(inputValue){const emojiPattern = /[\uD83C[\uDF00-\uDFFF]|\uD83D[\uDC00-\uDE4F]/; const hasEmoji = emojiPattern.test(inputValue); console.log('是否包含表情符号',hasEmoji);},// 过滤特殊符号checkSymbol(inputValue){console.log('前端过滤特殊符号');const specialSymbol = /[`~!@#$%^&*()+=|{}':;',/\/\[\].<>/?~!@#¥%……&*()——+|{}【】‘;:”“’。,、?]/ const hasSymbol = specialSymbol.test(inputValue)console.log('是否包含特殊符号',hasSymbol);}
后端处理方法
后端存入数据库的时候,将Mysql的编码从utf8转换成utf8mb4
这篇关于前端处理过滤,特殊字符以及输入法特殊表情符号emoji的正则方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!