unescape 不能再用!

优化前

(function ($) {

    $.getUrlParam = function (name) {
        var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
        var r = window.location.search.substr(1).match(reg);
        if (r != null) return unescape(r[2]); return null;
    }

})(jQuery);


kG0vTNYKRo0v6swj0z /HmiVXBc5fGhSYqNukLG38jXuAQAlL8t0bY/TeccXa/u1AfwRJwxENLEt5WzUwXSOJTuFApeumFSO7A2h7Q1ZIXJeT jZBhpOfY7 mTU8OJZGMqYHhfB9fx1cT2hB0dkp/ TZIYDasD8s0 qyg9eW69PTv8ks2iz7/NOUbWgAQrLH


优化后

(function ($) {
    $.getUrlParam = function (name) {
        var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
        var r = window.location.search.substr(1).match(reg);
        if (r != null) return decodeURIComponent(r[2]); return null;
    }
})(jQuery);


 var key = $.getUrlParam("myKey");
var encodedKey = encodeURIComponent(key);
document.location.href = "/MyController/MyAction?key=" + encodedKey;


kG0vTNYKRo0v6swj0z+/HmiVXBc5fGhSYqNukLG38jXuAQAlL8t0bY/TeccXa/u1AfwRJwxENLEt5WzUwXSOJTuFApeumFSO7A2h7Q1ZIXJeT+jZBhpOfY7+mTU8OJZGMqYHhfB9fx1cT2hB0dkp/+TZIYDasD8s0+qyg9eW69PTv8ks2iz7/NOUbWgAQrLH


escape()不对“+”编码。但是我们知道,网页在提交表单的时候,如果有空格,则会被转化为+字符。服务器处理数据的时候,会把+号处理成空格。所以,使用的时候要小心。
encodeURIComponent()
最后一个Javascript编码函数是encodeURIComponent()。与encodeURI()的区别是,它用于对URL的组成部分进行个别编码,而不用于对整个URL进行编码。
因此,“; / ? : @ & = + $ , #”,这些在encodeURI()中不被编码的符号,在encodeURIComponent()中统统会被编码。至于具体的编码方法,两者是一样。
encodeURIComponent()相比encodeURI()要更加彻底。
为什么优先使用encodeURIComponent而不是escape?
  escape方法并不编码字符+。而我们知道,在用户提交的表单字段中,如果有空格,则会被转化为+字符,而服务器解析的时候则会认为+号代表空格。由于这个缺陷,escape方法并不能正确地处理所有的非ASCII字符,你应当尽量避免使用escape方法,取而代之,你最好选择 encodeURIComponent()方法。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值