JS中的三种编码encodeUR、encodeURIComponent、escape()
2016-04-12 00:00
519 查看
摘要: JS中的三种编码encodeUR、encodeURIComponent、escape() 的区别和使用场合
一、encodeURI(str)和ecodeURIComponent(str)
都是把字符串作为参数,并对其进行编码,一般传入的参数是URI;两种方法都不会对ASCII码字母、数字、特定标点符号【- _ . ! ~ * ' ( ) 等等】进行编码,保持原形。
但是,encodeURI()不会对在 URI 中具有特殊含义的 ASCII 标点符号【如分隔符: , / ? : @ & 空格 = + $ # 等等】进行编码,还是保持原形;在 ecodeURIComponent(str)中 会对这些符号进行编码,编码成由一个或多个十六进制的转义序列表示。
测试代码:encodeURI(str)
结果:
测试代码:ecodeURIComponent(str)
结果:
二、escape()
主要是对字符串进行编码,一般不指URI
三、使用场合
1、如果只是编码字符串,和URL没关系,用escape
2、如果需要编码整个URL,然后使用这个URL,用encodeURI
3、当只需要编码URL中的参数时,用encodeURIComponent
一、encodeURI(str)和ecodeURIComponent(str)
都是把字符串作为参数,并对其进行编码,一般传入的参数是URI;两种方法都不会对ASCII码字母、数字、特定标点符号【- _ . ! ~ * ' ( ) 等等】进行编码,保持原形。
但是,encodeURI()不会对在 URI 中具有特殊含义的 ASCII 标点符号【如分隔符: , / ? : @ & 空格 = + $ # 等等】进行编码,还是保持原形;在 ecodeURIComponent(str)中 会对这些符号进行编码,编码成由一个或多个十六进制的转义序列表示。
测试代码:encodeURI(str)
document.write(encodeURI("http://www.yhpage.com")+ "<br />") document.write(encodeURI("http://www.yhpage.com/My test/")+ "<br />") document.write(encodeURI(",/?:@&=+$#-_.!~*'()"))
结果:
http://www.yhpage.com http://www.yhpage.com/My%20test/ ,/?:@&=+$# -_.!~*'()
测试代码:ecodeURIComponent(str)
<script type="text/javascript"> document.write(encodeURIComponent("http://www.yhpage.com")+ "<br />") document.write(encodeURIComponent("http://www.yhpage.com/My test/")+ "<br />") document.write(encodeURIComponent(",/?:@&=+$#")+ "<br />") document.write(encodeURIComponent("-_.!~*'()")) </script>
结果:
http%3A%2F%2Fwww.yhpage.com http%3A%2F%2Fwww.yhpage.com%2FMy%20test%2F %2C%2F%3F%3A%40%26%3D%2B%24%23 -_.!~*'()
二、escape()
主要是对字符串进行编码,一般不指URI
三、使用场合
1、如果只是编码字符串,和URL没关系,用escape
2、如果需要编码整个URL,然后使用这个URL,用encodeURI
3、当只需要编码URL中的参数时,用encodeURIComponent
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解
- call/apply/bind 的理解与实例分享