WEB基础之:JavaScript转义

本文详细介绍了JavaScript中的URI编码函数,包括encodeURI()、decodeURI()、encodeURIComponent()以及decodeURIComponent()的用法和注意事项。特别强调了encodeURIComponent()在处理用户输入以防止产生不可预知请求的重要性,并指出在POST请求中,空格通常需要转换为'+'。同时,文章提到了在编码不完整代理字符时可能抛出的URIError错误。
摘要由CSDN通过智能技术生成

1. encodeURI()

encodeURI() 函数通过将特定字符替换为转义序列来对统一资源标识符 (URI) 进行编码 。

encodeURI 会替换所有的字符,但不包括以下字符,即使它们具有适当的UTF-8转义序列:

类型 包含
保留字符 ; , / ? : @ & = + $
非转义的字符 字母 数字 - _ . ! ~ * ' ( )
数字符号 #

完整URI:

http://username:password@www.example.com:80/path/to/file.php?foo=316&bar=this+has+spaces#anchor

示例:

encodeURI("https://cn.bing.com/search?q=你好")
// "https://cn.bing.com/search?q=%E4%BD%A0%E5%A5%BD"

1.1 注意

  • encodeURI 自身无法产生能适用于HTTP GET 或 POST 请求的URI,例如对于 XMLHTTPRequests, 因为 “&”, “+”, 和 “=” 不会被编码,然而在 GET 和 POST 请求中它们是特殊字符。然而encodeURIComponent这个方法会对这些字符编码。
  • 如果试图编码一个非高-低位完整的代理字符,将会抛出一个 URIError错误,例如:
// 编码高-低位完整字符 ok
console.log(encodeURI('\uD800\uDFFF'));

// 编码单独的高位字符抛出 "Uncaught URIError: malformed URI sequence"
console.log(encodeURI('\uD800'));

// 编码单独的低位字符抛出 "Uncaught URIError: URI malformed"
console.log(encodeURI('\uDFFF'));
  • 如果URL需要遵循较新的RFC3986标准,那么方括号是被保留的(给IPv6),因此对于那些没有被编码的URL部分(例如主机),可以使用下面的代码:
function fixedEncodeURI (str) {
   
    return encodeURI(str).replace(/%5B/g, '[').replace(/%5D/g, ']');
}

2. decodeURI()

**decodeURI()** 函数能解码由encodeURI 创建或其它流程得到的统一资源标识符(URI)。

decodeURI("https://cn.bing.com/search?q=%E4%BD%A0%E5%A5%BD");
// "https://cn.bing.com/search?q=你好"

3. encodeURIComponent()

encodeURIComponent()函数通过将UTF-8编码的转义序列替换为某些字符的编码 URI

encodeURIComponent 转义除了如下所示外的所有字符

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值