使用encodeURIComponent() 函数解决js传参的特殊字符问题

时间:2022-11-04 18:28:18

在项目中使用了json格式的字符串进行传参,发现传到后台例如: ;/?:@&=+$,# 这些的特殊字符获取不到。于是想到json格式对这些特殊的参数无法处理。后来查资料发现可以使用encodeURIComponent() 函数解决js传参的特殊字符问题。

定义和用法

encodeURIComponent() 函数可把字符串作为 URI 组件进行编码。

语法

encodeURIComponent(URIstring)
参数 描述
URIstring 必需。一个字符串,含有 URI 组件或其他要编码的文本。

返回值

URIstring 的副本,其中的某些字符将被十六进制的转义序列进行替换。

说明

该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。

其他字符(比如 :;/?:@&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。

提示和注释

提示:请注意 encodeURIComponent() 函数 与 encodeURI() 函数的区别之处,前者假定它的参数是 URI 的一部分(比如协议、主机名、路径或查询字符串)。因此 encodeURIComponent() 函数将转义用于分隔 URI 各个部分的标点符号。



实例

Sting name1='zs1';

Sting name1='zs2';

Sting name1='zs3';

Sting name1='zs4';

Sting name1='zs5';

       dataList+="&person.name1"+encodeURIComponent(name1);

dataList+="&person.name2"+encodeURIComponent(name2);

dataList+="&person.name3"+encodeURIComponent(name3);

dataList+="&person.name4"+encodeURIComponent(name4);

dataList+="&person.name5"+encodeURIComponent(name5);

$.ajax({

type:"POST",

url:'',

dateType:dateList,

success:function(data){

}

});