前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >encodeURIComponent()函数在url传参中的作用和使用方法

encodeURIComponent()函数在url传参中的作用和使用方法

作者头像
德顺
发布2020-10-30 10:55:35
发布2020-10-30 10:55:35
11.4K00
代码可运行
举报
文章被收录于专栏:前端资源前端资源
运行总次数:0
代码可运行

为什么使用 encodeURIComponent()

在使用 URL 传参的时候,如果参数中有空格等特殊字符,浏览器可能只会读取到空格面前的内容,导部分致数据丢失。

可以使用 encodeURIComponent() 方法,将这些特殊字符进行转义,这样就可以正常读取了。

定义和用法:

encodeURIComponent() 函数可把字符串作为 URI 组件进行编码。

语法:
代码语言:javascript
代码运行次数:0
运行
复制
encodeURIComponent(URIstring)
参数:

URIstring必需。一个字符串,含有 URI 组件或其他要编码的文本。

返回值:

URIstring 的副本,其中的某些字符将被十六进制的转义序列进行替换。

注意:

1、该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。

2、其他字符(比如 :;/?:@&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。

3、请注意 encodeURIComponent() 函数 与 encodeURI() 函数的区别之处,前者假定它的参数是 URI 的一部分(比如协议、主机名、路径或查询字符串)。因此 encodeURIComponent() 函数将转义用于分隔 URI 各个部分的标点符号。

应用:

如果我们要将一个对象通过 URL 进行传输,可以将对象转成字符串,再用 encodeURIComponent() 函数进行转义:

代码语言:javascript
代码运行次数:0
运行
复制
encodeURIComponent(JSON.stringify(cardOBJ))

然后将接收的参数转换成对象:

代码语言:javascript
代码运行次数:0
运行
复制
JSON.parse(decodeURIComponent(params.cardOBJ))

这里的:

decodeURIComponent() 用于对 encodeURIComponent() 进行反转义。

JSON.stringify() 方法用于将 JavaScript 值转换为 JSON 字符串。

JSON.parse() 方法用于将一个 JSON 字符串转换为对象。

未经允许不得转载:w3h5 » encodeURIComponent()函数在url传参中的作用和使用方法

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 为什么使用 encodeURIComponent()
  • 定义和用法:
    • 语法:
    • 参数:
    • 返回值:
  • 注意:
  • 应用:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档