首页 > 其他分享 >js对于特殊字符的处理

js对于特殊字符的处理

时间:2024-08-02 16:57:24浏览次数:8  
标签:字符 encodeURIComponent console log 处理 replace js encodeURI 特殊字符

特殊字符的检查判断

const reg = /[`~!@#$%^&*()_\-+=<>?:"{}|,.\/;'\\[\]·!#¥(——):;“”‘、,|《。》?、【】[\]]/;
if(reg.test(changeGroupName.value)){
  message.warning('文件夹名称不能包含~!#$%个&*()=+/N[];∵:",?/<>等字符')
  return
}

 ​特殊字符替换

const onKeyUp = ()=>{
  changeGroupName.value=changeGroupName.value.replace(/([^0-9A-z\u4e00-\u9fa5]|[\^_])/g,'');
}

特殊字符串转码

​encodeURI

一个新字符串,表示提供的字符串编码为统一资源标识符 (URI)。

encodeURI 会替换所有的字符,但不包括以下字符,即使它们具有适当的 UTF-8 转义序列:

类型包含
保留字符; , / ? : @ & = + $
非转义的字符字母 数字 - _ . ! ~ * ' ( )
数字符号#

解决的方法: 
1、replace() 方法如果直接用str.replace("-","!") 只会替换第一个匹配的字符. 
而str.replace(/\-/g,"!")则可以替换掉全部匹配的字符(g为全局标志)。 
replace() 
js中替换字符变量如下: 
data2=data2.replace(/\%/g,"%25"); 
data2=data2.replace(/\#/g,"%23"); 
data2=data2.replace(/\&/g,"%26"); 

符号解释转义
#用来标志特定的文档位置

%23

%对特殊字符进行编码%25
&分隔不同的变量值对%26
+在变量值中表示空格%2B
/表示目录路径%2F
=用来连接键和值

%3D

\表示目录路径%5C
?表示查询字符串的开始%3F
空格空格

%20

.句号%2E
:冒号%3A
keyword=encodeURI(searchContent.value)
keyword=keyword.replace(/\#/g,"%23"); 

2、使用encodeURIComponent这个方法会对这些字符编码。

encodeURIComponent

encodeURIComponent 转义除了如下所示外的所有字符:

不转义的字符:
    A-Z a-z 0-9 - _ . ! ~ * ' ( )

 原字串作为 URI 组成部分被被编码后的新字符串。

encodeURIComponent() 和 encodeURI 有以下几个不同点:

var set1 = ";,/?:@&=+$"; // 保留字符
var set2 = "-_.!~*'()"; // 不转义字符
var set3 = "#"; // 数字标志
var set4 = "ABC abc 123"; // 字母数字字符和空格

console.log(encodeURI(set1)); // ;,/?:@&=+$
console.log(encodeURI(set2)); // -_.!~*'()
console.log(encodeURI(set3)); // #
console.log(encodeURI(set4)); // ABC%20abc%20123 (空格被编码为 %20)

console.log(encodeURIComponent(set1)); // %3B%2C%2F%3F%3A%40%26%3D%2B%24
console.log(encodeURIComponent(set2)); // -_.!~*'()
console.log(encodeURIComponent(set3)); // %23
console.log(encodeURIComponent(set4)); // ABC%20abc%20123 (空格被编码为 %20)
var  u="index.php?blogId=1&op=Default"; 
var  getURL="http://www.simplelife.cn/test.php?p="+encodeURI(u);

最终的getURL的值为: 

 http://www.simplelife.cn/test.php?p=index.php?blogId=1&op=Default

参数u中的字符"&op=Default",将不会作为字符串参数传递到服务器端,而是当作test.php的参数传递过去了,因为对"&op=Default"中的字符"&"没有做编码。 

文字及特殊字符解码

decodeURI(encodedURI)

decodeURIComponent(encodedURI)

标签:字符,encodeURIComponent,console,log,处理,replace,js,encodeURI,特殊字符
From: https://blog.csdn.net/m0_56772756/article/details/140873047

相关文章

  • JS之File对象与base64字符串之间的相互转换
    File对象有两种形态,在请求时为:控制台输出为:从formData中获得fileList对应的File对象,并转换为base64字符串,再转换回File对象,代码示例如下:constfileList=uploadFormData.get("fileList");console.log(fileList);constreader=newFileReader();reader.readAsDataURL(......
  • 图像处理案例02
    手指拖拽屏幕上的方块儿1步骤:1.opencv获取视频流2.获取手指关节关键点坐标3.判断手指是否在方块上4.如果在方块上,方块跟着手指移动2代码importcv2importnumpyasnpimportmathimportmediapipeasmp##检测手掌参数设置mp_drawing=mp.solutions.drawing_util......
  • wincc v8 连接opc ua 变量失败处理
     kepserverex作为opc服务器.wincc更改计算机名称后opcua变量连接不上.需要重新安装证书.打开证书管理器WinCCCertificateManager"C:\ProgramFiles(x86)\Siemens\WinCC\bin\Siemens.CertManagerWinApp.exe"组态里面添加设备,当前计算机名,添加证书再右键安装所有证书.......
  • maven项目pom文件查看架包依赖处理架包冲突问题
    在运行maven项目的时候由于依赖冲突出现如下问题 项目中依赖了多个不同版本的slf4j类库,我们可以使用dependency:tree命令:  找到冲突的依赖,向上找到引入依赖的根源,在对应的pom文件里,添加 <exclusions> 标签即可<dependency><groupId>com.baidu.aip</groupId>......
  • 【学术会议征稿】第三届图像处理、计算机视觉与机器学习国际学术会议(ICICML 2024)
    第三届图像处理、计算机视觉与机器学习国际学术会议(ICICML2024)20243rd InternationalConferenceonImageProcessing,ComputerVisionandMachineLearning 重要信息大会官网:参会投稿/了解会议详情大会时间:2024年11月22日-24日 大会地点:中国深圳接受/拒稿......
  • 【Spark高级应用】使用Spark进行高级数据处理与分析
    Spark高级应用使用Spark进行高级数据处理与分析引言在大数据时代,快速处理和分析海量数据是每个企业面临的重大挑战。ApacheSpark作为一种高效的分布式计算框架,凭借其高速、易用、通用和灵活的特点,已经成为大数据处理和分析的首选工具。本文将深入探讨如何使用Spark进行......
  • Oracle处理时间戳和时间格式的日期
    一、将时间格式转换为时间戳格式select(to_date('2024-08-0215:00:00','yyyy-mm-ddhh24:mi:ss')-to_date('1970-01-0108:00:00','yyyy-mm-ddhh24:mi:ss'))*24*60*60*1000AStimestampsfromdual;--1722582000000二、将时间戳格式......
  • SAP ABAP 基础与入门(一、数据类型定义与字符串处理)
    1.   基础1.1.  基本数据类型C、N、D、T、I、F、P、X、string、XstringP:默认为8字节,最大允许16字节。最大整数位:16*2=32-1=31-14(允许最大小数位数)=17位整数位类型最大长度(字符数)默认长度说明C1~262143个字符1 字符普通字符(常用于名称、备......
  • PixiJS源码分析系列:第四章 响应 Pointer 交互事件(上篇)
    响应Pointer交互事件(上篇)上一章我们分析了sprite在canvasRenderer上的渲染,那么接下来得看看交互上最重要的事件系统了最简单的demo还是用一个最简单的demo演示example/sprite-pointerdown.html为sprite添加一个pointerdown事件,即点击事件,移动设备上就是touc......
  • 前端使用JS内置Blob实现下载各种形式的文件实例
    在前端开发中,JavaScript的Blob对象允许你创建一个包含原始数据的类文件对象。使用Blob可以轻松实现在客户端生成和下载各种类型的文件,例如文本文件、图片、CSV等。下面是一些使用Blob实现文件下载的示例:1.下载文本文件functiondownloadTextFile(filename,text){c......