encodeURI和encodeURIComponent区别

Posted jelina

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了encodeURI和encodeURIComponent区别相关的知识,希望对你有一定的参考价值。

    var str1="http://baidu.com";
    var str2="http://baidu.com/~#$&*(_+";
    var str3="http://baidu.com/my page";
    console.log(encodeURI(str1));
    console.log(encodeURI(str2));
    console.log(encodeURI(str3));

  运行结果:

技术分享图片

  encodeURI() 不会转义:;/?:@&=+$,#-_.!~*‘(),但会对空格转义,目的是对 URI 进行完整的编码

  

    var str4="http://baidu.com";
    var str5="http://baidu.com/:;/?:@&=+$,#";
    var str6="http://baidu.com/my page/04563";
    var str7="http://baidu.com/-_.!~*‘()";
    console.log(encodeURIComponent(str4));
    console.log(encodeURIComponent(str5));
    console.log(encodeURIComponent(str6));
    console.log(encodeURIComponent(str7));

  运行结果:

  http%3A%2F%2Fbaidu.com
  http%3A%2F%2Fbaidu.com%2F%EF%BC%9A%3B%2F%3F%3A%40%26%3D%2B%24%2C%23
  http%3A%2F%2Fbaidu.com%2Fmy%20page%2F04563
  http%3A%2F%2Fbaidu.com%2F-_.!~*‘()

  encodeURIComponent() 不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ‘ ( ),目的是将转义用于分隔 URI 各个部分的标点符号

 

  两个方法的解码分别对应decodeURI和decodeURIComponent




以上是关于encodeURI和encodeURIComponent区别的主要内容,如果未能解决你的问题,请参考以下文章

encodeURIComponent和encodeURI的区别

javascript encodeURI和encodeURIComponent的比较

encodeURI和encodeURIComponent区别

encodeURI()和encodeURIComponent() 区别

escape()encodeURI()encodeURIComponent() 编码解码

encodeURI和encodeURIComponent的区别