浏览器编码函数escape(),encodeURI(),encodeURIComponent()的区别

浏览器编码函数escape(),encodeURI(),encodeURIComponent()的区别

1、escape()
escape()是js编码函数中最古老的一个。实际上,escape()不能直接用于URL编码,它的真正作用是返回一个字符的Unicode编码值。比如“你好”的返回结果是"%u4F60%u597D"。无论网页的原始编码是什么,一旦被Javascript编码,就都变为unicode字符。也就是说,Javascipt函数的输入和输出,默认都是Unicode字符。

javascript:escape("你好");
//输出 "%u4F60%u597D"
解码
javascript:unescape("%u4F60%u597D");
//输出 "你好"

2、encodeURI()
encodeURI是对整个URL进行编码,因此除了常见的符号以外,对其他一些在网址中有特殊含义的符号“; / ? : @ & = + $ , #”,也不进行编码。编码后,它输出符号的utf-8形式,并且在每个字节前加上%,需要注意的是,它不对单引号’编码。

encodeURI("https://mp.csdn.net?=k=hello world");
//输出 "https://mp.csdn.net?=k=hello%20world"

它对应的解码函数是decodeURI()。

decodeURI("https%3A//mp.csdn.net/mdeditor%23Markdown_2");
//输出 "https://mp.csdn.net?=k=hello world"

3、encodeURIComponent()
与encodeURI()的区别是,它用于对URL的组成部分进行个别编码,而不用于对整个URL进行编码。因此,“; / ? : @ & = + $ , #”,这些在encodeURI()中不被编码的符号,在encodeURIComponent()中统统会被编码,所以encodeURIComponent()相比encodeURI()要更加彻底。至于具体的编码方法,两者是一样。

encodeURIComponent("https://mp.csdn.net?=k=hello world");
//输出 "https%3A%2F%2Fmp.csdn.net%3F%3Dk%3Dhello%20world"

它对应的解码函数是decodeURIComponent()。

decodeURIComponent("https%3A%2F%2Fmp.csdn.net%3F%3Dk%3Dhello%20world");
//输出 "https://mp.csdn.net?=k=hello world"
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、姓名存储和展现 1. 按学生总表编码存储 李洋薛鹏磊按照学生总表进行编码,并将编码进行存储或者发送 左边是客户...
    果芽软件阅读 5,204评论 0 0
  • js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解...
    奔跑的兔子_阅读 491评论 0 0
  • 去年冬天在书店买书的时老板送了我一小束绿萝。当时真是好害怕它过不过那个冬天呀,但是它的生命力似乎很顽强。今天去看它...
    山鬼乃嵬阅读 308评论 0 0
  • 好朋友U休完产假不久,老公每天加班晚归,她一个人疲于应付工作照顾孩子,还要面对婆婆的满腹牢骚,忍不住向我抱怨: “...
    楚雯谈心阅读 269评论 0 0
  • 距离春节越来越近了,有的朋友已经放假回家,有的正在计划着怎么度过春节假期。 他们的计划都大同小异,回家春节前和朋友...
    一只不说话的猫阅读 179评论 0 1