escape() VS encodeURI() VS encodeURIComponent()

问:

当向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 + “&param2=99”;
得到完整的URL:

http://www.domain.com/?param1=http%3A%2F%2Fxyz.com%2F%Ffa%3D12%26b%3D55&param2=99
更详细的解释点击这里: http://en.wikipedia.org/wiki/Percent-encoding

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值