• 技术文章 >web前端 >js教程

    javascript如何实现URL的转码与解码?

    不言不言2018-09-14 17:48:04原创2342
    本篇文章给大家带来的内容是关于javascript如何实现URL的转码与解码?有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

    1. escape 和 unescape

    escape()不能直接用于URL编码,它的真正作用是返回一个字符的Unicode编码值。

    采用unicode字符集对指定的字符串除0-255以外进行编码。所有的空格符、标点符号、特殊字符以及更多有联系非ASCII字符都将被转化成%xx格式的字符编码(xx等于该字符在字符集表里面的编码的16进制数字)。比如,空格符对应的编码是%20。
    escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z。

    escape()函数用于js对字符串进行编码,不常用。

    编码:

    escape('http://www.baidu.com?name=zhang@xiao@jie&order=1')

       结果:"http%3A//www.baidu.com%3Fname%3Dzhang@xiao@jie%26order%3D1"

       escape('张')

       结果:"%u5F20"

    解码:

    unescape("http%3A//www.baidu.com%3Fname%3Dzhang@xiao@jie%26order%3D1")

       结果:"http://www.baidu.com?name=zhang@xiao@jie&order=1"

       unescape("%u5F20")

       结果:"张"

    2. encodeURI 和 decodeURI

    把URI字符串采用UTF-8编码格式转化成escape各式的字符串。
    encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z

    encodeURI()用于整个url编码

    编码:

    encodeURI('http://www.baidu.com?name=zhang@xiao@jie&order=1')

    结果:"http://www.baidu.com?name=zhang@xiao@jie&order=1"

    解码:

    decodeURI("http%3A//www.baidu.com%3Fname%3Dzhang@xiao@jie%26order%3D1")

    结果:"http%3A//www.baidu.com%3Fname%3Dzhang@xiao@jie%26order%3D1"

    3. encodeURIComponent 和 decodeURIComponent

    与encodeURI()的区别是,它用于对URL的组成部分进行个别编码,而不用于对整个URL进行编码。

    因此,"; / ? : @ & = + $ , #",这些在encodeURI()中不被编码的符号,在encodeURIComponent()中统统会被编码。至于具体的编码方法,两者是一样。把URI字符串采用UTF-8编码格式转化成escape格式的字符串。

    encodeURIComponent() 用于参数的传递,参数包含特殊字符可能会造成间断。

    编码:

    encodeURIComponent('http://www.baidu.com?name=zhang@xiao@jie&order=1')

    结果:"http%3A%2F%2Fwww.baidu.com%3Fname%3Dzhang%40xiao%40jie%26order%3D1"

    解码:

    decodeURIComponent("http%3A%2F%2Fwww.baidu.com%3Fname%3Dzhang%40xiao%40jie%26order%3D1")

    结果:"http://www.baidu.com?name=zhang@xiao@jie&order=1"

    总结:

    escape()不能直接用于URL编码,它的真正作用是返回一个字符的Unicode编码值。比如"春节"的返回结果是%u6625%u8282,,escape()不对"+"编码

    主要用于汉字编码,现在已经不提倡使用。

    encodeURI()是Javascript中真正用来对URL编码的函数。
    编码整个url地址,但对特殊含义的符号"; / ? : @ & = + $ , #",也不进行编码。对应的解码函数是:decodeURI()。

    encodeURIComponent()
    能编码"; / ? : @ & = + $ , #"这些特殊字符。对应的解码函数是decodeURIComponent()。

    我想要传递带&符号的网址,所以用encodeURIComponent()

    以上就是javascript如何实现URL的转码与解码?的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:javascript 转码 解码
    上一篇:springboot和element-axios如何实现跨域请求(代码) 下一篇:代码详解JavaScript中JSON的用法
    大前端线上培训班

    相关文章推荐

    • JavaScript根据CSS的Media Queries来判断浏览设备的方法_javascript技巧• js实现的简单图片浮动效果完整实例_javascript技巧• 浅谈Bootstrap table中父子表和行列调序的用法• bootstrap网页框架的使用方法_javascript技巧• BootStrap文件上传样式超好看【持续更新】_javascript技巧

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网