escape() VS encodeURI() VS encodeURIComponent()
2016-06-07 16:42
731 查看
问:
当向web server传送一条query string时,正确的编码方法是哪一个?
使用escape?
escape(“% +&=”);
或者 encodeURI() 或者encodeURIComponent()?
encodeURI(“http://www.google.com?var1=value1&var2=value2“);
encodeURIComponent(“var1=value1&var2=value2”);
答:
escape()
不要用这个。
encodeURI()
当你需要一个合法的URL时,使用Use encodeURI :
encodeURI(“http://www.google.com/a file with spaces.html”)
返回:
http://www.google.com/a%20file%20with%20spaces.html
如果你调用encodeURIComponent,你将得到无效的URL :
http%3A%2F%2Fwww.google.com%2Fa%20file%20with%20spaces.html
encodeURIComponent()
encodeURIComponent是用来编码URL参数的:
param1 = encodeURIComponent(“http://xyz.com/?a=12&b=55“)
在URL中使用这个参数:
url = “http://domain.com/?param1=” + param1 + “¶m2=99”;
得到完整的URL:
http://www.domain.com/?param1=http%3A%2F%2Fxyz.com%2F%Ffa%3D12%26b%3D55¶m2=99
更详细的解释点击这里: http://en.wikipedia.org/wiki/Percent-encoding
当向web server传送一条query string时,正确的编码方法是哪一个?
使用escape?
escape(“% +&=”);
或者 encodeURI() 或者encodeURIComponent()?
encodeURI(“http://www.google.com?var1=value1&var2=value2“);
encodeURIComponent(“var1=value1&var2=value2”);
答:
escape()
不要用这个。
encodeURI()
当你需要一个合法的URL时,使用Use encodeURI :
encodeURI(“http://www.google.com/a file with spaces.html”)
返回:
http://www.google.com/a%20file%20with%20spaces.html
如果你调用encodeURIComponent,你将得到无效的URL :
http%3A%2F%2Fwww.google.com%2Fa%20file%20with%20spaces.html
encodeURIComponent()
encodeURIComponent是用来编码URL参数的:
param1 = encodeURIComponent(“http://xyz.com/?a=12&b=55“)
在URL中使用这个参数:
url = “http://domain.com/?param1=” + param1 + “¶m2=99”;
得到完整的URL:
http://www.domain.com/?param1=http%3A%2F%2Fxyz.com%2F%Ffa%3D12%26b%3D55¶m2=99
更详细的解释点击这里: http://en.wikipedia.org/wiki/Percent-encoding
相关文章推荐
- 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 的理解与实例分享