关闭

js中escape,encodeURI,encodeURIComponent区别

标签: js
359人阅读 评论(0) 收藏 举报
分类:
1.escape()
(1)该方法不会对 ASCII 字母和数字进行编码,也不会对下面这些 ASCII 标点符号进行编码: * @ - _ + . / 。其他所有的字符都会被转义序列替换。
(2)escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z
(3)ECMAScript v3 反对使用该方法,应用使用 decodeURI() 和 decodeURIComponent() 替代它。


2.encodeURI()
(1)该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。该方法的目的是对 URI 进行完整的编码,因此对以下在 URI 中具有特殊含义的 ASCII 标点符号,encodeURI() 函数是不会进行转义的:;/?:@&=+$,#
(2)如果 URI 组件中含有分隔符,比如 ? 和 #,则应当使用 encodeURIComponent() 方法分别对各组件进行编码。
(3)encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
(4) 进行url跳转时可以整体使用encodeURI
如:Location.href=encodeURI("http://cang.baidu.com/do/s?word=百度&ct=21");


3.encodeURIComponent()
(1)该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。其他字符(比如 :;/?:@&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。
(2)请注意 encodeURIComponent() 函数 与 encodeURI() 函数的区别之处,前者假定它的参数是 URI 的一部分(比如协议、主机名、路径或查询字符串)。因此 encodeURIComponent() 函数将转义用于分隔 URI 各个部分的标点符号。
(3)encodeURIComponent不编码字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z
(4) 传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。

如:<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7& u='+encodeURIComponent("http://cang.baidu.com/bruce42")+'">退出</a& gt;');</script>   


测试:

		String url = "http://abc/aaa.html?a=b&b=c&c=参数";
		System.out.println(escape(url));
		System.out.println(encodeURIComponent(url));
		System.out.println(encodeURI(url));
输出
http%3A//abc/aaa.html%3Fa%3Db%26b%3Dc%26c%3D%u53C2%u6570
http%3A%2F%2Fabc%2Faaa.html%3Fa%3Db%26b%3Dc%26c%3D%E5%8F%82%E6%95%B0
http://abc/aaa.html?a=b&b=c&c=%E5%8F%82%E6%95%B0

结果:

escape将中文转为unicode编码,还转义了些特殊字符

encodeURIComponent基本上除了英文字母和数字全都转义了

encodeURI只转义了中文,且中文编码格式和encodeURIComponent一样,其它的完好保存下来了


通过对三个函数的分析,我们可以知道:escape()除了 ASCII 字母、数字和特定的符号外,对传进来的字符串全部进行转义编码,因此如果想对URL编码,最好不要使用此方法。而encodeURI() 用于编码整个URI,因为URI中的合法字符都不会被编码转换。encodeURIComponent方法在编码单个URIComponent(指请求参 数)应当是最常用的,它可以讲参数中的中文、特殊字符进行转义,而不会影响整个URL。


0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

JS 字符串编码函数(解决URL特殊字符传递问题):escape()、encodeURI()、encodeURIComponent()区别详解

JavaScript中有三个可以对字符串编码的函数,分别是: escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent 。 下面简单介绍一下它们的区别 1 escape()函数 ...
  • jumtre
  • jumtre
  • 2016-05-13 11:16
  • 3094

.Net工作流项目实战——前台到后台传值的编码、解码解决方案

在页面传值的过程中,通过url进行传值,通常会涉及一些隐私信息,中文信息。那么对于这些信息进行重新编码和解码就是一个刚需!本次在项目中,要从一个页面通过Js代码,给另一个页面传参,通过url传值的方式进行数据通信。我用到的是第三种解决方案,传输的参数中可能涉及到中文。如果不进行重新编码和解码的话,就...
  • u011500356
  • u011500356
  • 2016-05-15 20:21
  • 1132

谈谈encodeURI和encodeURIComponent以及escape的区别与应用

encodeURI和encodeURIComponent以及escape,这三个都是用来编码的,本篇文章给大家介绍encodeURI和encodeURIComponent以及escape的区别与应用,感兴趣的朋友一起学习吧 首先,我们都知道这三个东西都是用来编码的先来说encodeURI()和enc...
  • xuxiaoping1989
  • xuxiaoping1989
  • 2016-12-27 16:00
  • 137

两次调用encodeURI来解决乱码问题

encodeURL函数主要是来对URI来做转码,它默认是采用的UTF-8的编码. UTF-8编码的格式:一个汉字来三个字节构成,每一个字节会转换成16进制的编码,同时添加上%号. 假设页面端输入的中文是一个“中”,按照下面步骤进行解码 1.第一次encodeURI,按照utf-8方式获取字节数组变成...
  • u012316120
  • u012316120
  • 2015-08-28 16:29
  • 1668

编码、解码之区别详解:escape()、encodeURI()、encodeURIComponent()

JavaScript中有三个可以对字符串编码的函数,分别是: escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent 。 下面简单介绍一下它们的区别 1 escape()函数 定...
  • ht_gaogao
  • ht_gaogao
  • 2013-06-18 12:54
  • 580

为什么需要JS里常需要做两次encodeURI(url)

最近项目里经常出现前后端传送出现乱码的情况,不少同事问一为什么经常需要在JS里进行两次编码,这里进行下说明: 一般情况下, 发送 encodeURIComponent(parmeName)+"="+encodeURIComponent(parmeValue); 接收时...
  • posonrick
  • posonrick
  • 2016-05-31 09:13
  • 3577

encodeURIComponent传入后台解码

$(document).ready(function() { $("#name").focus(); $("#inputForm").validate({ rules:{ code:{ required...
  • carl_jiang
  • carl_jiang
  • 2017-04-28 08:42
  • 2796

页面传参乱码问题与escape()、encodeURI()、encodeURIComponent()区别详解

在用javascript对URL字符串进行编码中,虽然escape()、encodeURI()、encodeURIComponent()三种方法都能对一些影响URL完整性的特殊字符进行过滤。但后两者是将字符串转换为UTF-8的方式来传输,解决了页面编码不一至导致的乱码问题。例如:发送页与接受页的编码...
  • lanwilliam
  • lanwilliam
  • 2015-09-24 12:50
  • 278

JS和JAVA中常用的编码转码函数

js中escape,encodeURI,encodeURIComponent函数和unescape,decodeURI和decodeURIComponent函数的功能 1.escape方法对String对象编码,escape方法返回一个包含了charstring内容的字符串值(Unicode格式)。...
  • kkdelta
  • kkdelta
  • 2013-12-17 16:42
  • 13577

编码URLEncoder和解码URLDecoder的UTF-8到GBK的转码

package com.kk; import java.io.UnsupportedEncodingException; import java.net.URLDecoder; import java.net.URLEncoder; public class Charencoding { ...
  • typa01_kk
  • typa01_kk
  • 2014-10-22 12:39
  • 22538
    个人资料
    • 访问:114598次
    • 积分:1252
    • 等级:
    • 排名:千里之外
    • 原创:0篇
    • 转载:138篇
    • 译文:1篇
    • 评论:6条
    最新评论