阿西河

所有教程

公众号
🌙
阿西河前端的公众号

我的收藏

    最近访问  (文章)

      教程列表

      抓包专区
      测试专区

      JS encodeURI()

      功能

      encodeURI() 函数通过将特定字符的每个实例替换为一个、两个、三或四转义序列来对统一资源标识符 (URI) 进行编码 (该字符的 UTF-8 编码仅为四转义序列)由两个 “代理” 字符组成)。

      语法

      encodeURI(URI)
      

      参数

      URI

      一个完整的 URI.

      返回值

      一个新字符串,表示提供的字符串编码为统一资源标识符 (URI)。

      描述

      假定一个 URI 是完整的 URI,那么无需对那些保留的并且在 URI 中有特殊意思的字符进行编码。

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

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

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

      请注意,encodeURI 自身无法产生能适用于 HTTP GET 或 POST 请求的 URI,例如对于 XMLHTTPRequests, 因为 “&”, “+”, 和 “=” 不会被编码,然而在 GET 和 POST 请求中它们是特殊字符。然而 encodeURIComponent 这个方法会对这些字符编码。

      另外,如果试图编码一个非高 - 低位完整的代理字符,将会抛出一个 URIError 错误,例如:

      // 编码高-低位完整字符 ok
      console.log(encodeURI('\uD800\uDFFF'));
      
      // 编码单独的高位字符抛出 "Uncaught URIError: URI malformed"
      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, ']');
      }
      

      规范

      规范状态备注
      ECMAScript 3rd Edition (ECMA-262)Standard初始定义
      ECMAScript 5.1 (ECMA-262)
      encodeURI
      Standard
      ECMAScript 2015 (6th Edition, ECMA-262)
      encodeURI
      Standard
      ECMAScript Latest Draft (ECMA-262)
      encodeURI
      Draft
      目录
      目录