JS对字符串编码的几种方式使用指南
作者:bea
函数描述 encodeURI()把字符串编码为 URI encodeURIComponent()把字符串编码为 URI 组件 escape()对字符串进行编码 上面是查询来自w3school的资料。那么三者之间有什么区别呢,请容我测试测试。 代码如下: var str = " http://localhost:8080/Product/index?id=123&attr=456&area=中国"; console.log(encodeURI(str))
函数 描述 encodeURI() 把字符串编码为 URI encodeURIComponent() 把字符串编码为 URI 组件 escape() 对字符串进行编码
上面是查询来自w3school的资料。那么三者之间有什么区别呢,请容我测试测试。
代码如下:
var str = "
http://localhost:8080/Product/index?id=123&attr=456&area=中国";
console.log(encodeURI(str));
console.log(encodeURIComponent(str));
console.log(escape(str));
打印结果如下:
代码如下:
http://localhost:8080/Product/index?id=123&attr=456&area=%E4%B8%AD%E5%9B%BD
http%3A%2F%2Flocalhost%3A8080%2FProduct%2Findex%3Fid%3D123%26attr%3D456%26area%3D%E4%B8%AD%E5%9B%BD
http%3A//localhost%3A8080/Product/index%3Fid%3D123%26attr%3D456%26area%3D%u4E2D%u56FD
可以看出,
encodeURI不会对:/?&等uri中起分割作用的字符进行编码;
encodeURIComponent则会。
观察escape则发现,:?&都被转码了,而/没有,w3school解释是,escape函数会对ascii码中字母、数字及符号( * @ - _ + . / )之外的所有字符进行编码。
另外,我们可以看出escape对汉字“中国”编码后结果与前两者不同。W3SCHOOL也建议不使用该方法,用前两者代替。
以上所述就是本文的全部内容了,希望对大家学习javascript能够有所帮助。
有用 | 无用
上面是查询来自w3school的资料。那么三者之间有什么区别呢,请容我测试测试。
代码如下:
var str = "
http://localhost:8080/Product/index?id=123&attr=456&area=中国";
console.log(encodeURI(str));
console.log(encodeURIComponent(str));
console.log(escape(str));
打印结果如下:
代码如下:
http://localhost:8080/Product/index?id=123&attr=456&area=%E4%B8%AD%E5%9B%BD
http%3A%2F%2Flocalhost%3A8080%2FProduct%2Findex%3Fid%3D123%26attr%3D456%26area%3D%E4%B8%AD%E5%9B%BD
http%3A//localhost%3A8080/Product/index%3Fid%3D123%26attr%3D456%26area%3D%u4E2D%u56FD
可以看出,
encodeURI不会对:/?&等uri中起分割作用的字符进行编码;
encodeURIComponent则会。
观察escape则发现,:?&都被转码了,而/没有,w3school解释是,escape函数会对ascii码中字母、数字及符号( * @ - _ + . / )之外的所有字符进行编码。
另外,我们可以看出escape对汉字“中国”编码后结果与前两者不同。W3SCHOOL也建议不使用该方法,用前两者代替。
以上所述就是本文的全部内容了,希望对大家学习javascript能够有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- Javascript递归打印Document层次关系实例分析
- Javascript节点关系实例分析
- 自己编写的支持Ajax验证的JS表单验证插件
- Javascript中prototype属性实现给内置对象添加新的方法
- Javascript进制转换实例分析
- Javascript中For In语句用法实例
- Javascript中With语句用法实例
- javascript用函数实现对象的方法
- javascript中动态函数用法实例分析
- javascript函数特点实例分析
- JavaScript里实用的原生API汇总
- javascript中attachEvent用法实例分析
- javascript实现Table间隔色以及选择高亮(和动态切换数据)的方法
- javascript清空table表格的方法
- AngularJS的内置过滤器详解
- javascript实现带下拉子菜单的导航菜单效果
- javascript实现dom动态创建省市纵向列表菜单的方法
- javascript基于DOM实现权限选择实例分析
- javascript中DOM复选框选择用法实例