js有哪几种传参方式?

大家好,我是IT修真院深圳分院第01期学员,一枚正直善良的web程序员。

今天给大家分享一下,修真院官网 JS任务中可能会使用到的知识点:

js有哪几种传参方式?


1.背景介绍

所有函数的参数都是按值传递的,也就是说把函数外部的值赋值给函数内部的参数,就和把值从一个变量赋值到另一个变量一样。

————《js高级程序设计》

有的人可能会把这里的js传参方式,理解成js函数中的参数传递,但是呢,我们所要讲的是页面之间的数据传递。

传统的前端开发中,页面之间是少有参数交互的,甚至没有,而在如今的前端环境下, 一个稍微正式点的项目都不可能少了页面间传参,页面的跨越、服务器后台进行数据请求等,都需要一个或多个传参的方法。 那么参数在不同的页面间进行传递,一个页面的参数被另一页面使用,如何才能做到不同页面间进行参数传递?

在JS中有多种页面传递参数的方法:

一、URL

把参数值附在url后面传递到其他页面

二、H5 web storage

localStroage 和 sessionStorage

三、Cookie

使用浏览器Cookie传递参数

四、Form 表单

Form表单通过URL传递参数



2.知识剖析

2.1、URL

A. URL地址传递参数

把参数值附在url后面传递到其他页面

如:http://xxx.com/login.html?user=lol&pwd=66666

其中“user=lol”和“pwd=66666”就是我们传递的参数名称和值。

url和参数之间用"?"隔开,多个参数之间用"&"符号连接。

URL地址传递参数的几个特点:

优点:

1、 URL地址法简洁易用,可同时传递多个字符型参数;

2、 URL地址法可以很方便的在页面之间切换并传递参数,无需额外的处理,基于正常情况比较不会性能损失;

不足:

3、 URL传递参数长度受限,最大为2K;

4、 URL只能传递字符型参数,传递中文时,由于发送页面和接收页面的字符编码方式不一样而导致参数解析处理错误,参数包含中文时可能出现乱码或者参数接收错误;

5、 信息泄露:URL地址在客户端可见,所以涉及隐私的参数需进行加密后才能进行传递,不加密传输会导致信息泄露,产生安全隐患。

2.2、H5 WEB STORAGE

1、sessionStorage用于本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才能访问并且当会话结束后数据也随之销毁。因此sessionStorage不是一种持久化的本地存储,仅仅是会话级别的存储。

例子:菜鸟教程

2、localStorage HTML5本地存储web storage特性的API之一,用于将大量数据(最大5M)保存在浏览器中

. 保存后数据永远存在不会失效过期,除非手动清除。

. 不参与网络传输。

. 一般用于性能优化,可以保存图片、js、css、html 模板、大量数据。

3、数据以 键/值 (key/value)对存在, web网页的数据只允许该域访问使用

4、不管是 localStorage,还是 sessionStorage,可使用的API都相同,常用的有如下几个(以localStorage为例):

保存数据:localStorage.setItem(key,value);

读取数据:localStorage.getItem(key);

删除单个数据:localStorage.removeItem(key);

删除所有数据:localStorage.clear();

得到某个索引的key:localStorage.key(index);

5、数据储存:

在有多组数据需要储存时,一般:

.建立一个新的对象,然后将多组数据储存在对象中,

.使用 JSON.stringify() 来将对象转换为字符串,

.使用localStorage.setItem(key,value);保存数据。

6、数据提取:

.使用localStorage.getItem(key)读取数据

. 使用 JSON.parse 方法将字符串转换为 JSON 对象。

. 直接引用对象的各个值。

例子:菜鸟教程

2.3、COOKIE

Cookie是什么

Cookie是当你浏览某网站时,网站存储在你机器上的一个小文本文件, 它记录了你的用户ID,密码、浏览过的网页、停留的时间等信息,当你再次来到该网站时, 网站通过读取Cookie,得知你的相关信息,就可以做出相应的动作,如在页面显示欢迎你的标语, 或者让你不用输入ID、密码就直接登录等等

Cookie一般有两个作用。

第一个作用是识别用户身份。

比如用户 A 用浏览器访问了 http://a.com,那么 http://a.com 的服务器就会立刻给 A 返回一段数据「uid=1」(这就是Cookie)。当 A 再次访问 http://a.com 的其他页面时,就会附带上「uid=1」这段数据。

同理,用户 B 用浏览器访问 http://a.com 时,http://a.com 发现 B 没有附带 uid 数据,就给 B 分配了一个新的 uid,为2,然后返回给 B 一段数据「uid=2」。B 之后访问 http://a.com 的时候,就会一直带上「uid=2」这段数据。

借此,http://a.com 的服务器就能区分 A 和 B 两个用户了。

第二个作用是记录历史。

假设 http://a.com 是一个购物网站,当 A 在上面将商品 A1 、A2 加入购物车时,JS 可以改写 Cookie,改为「uid=1; cart=A1,A2」,表示购物车里有 A1 和 A2 两样商品了。

这样一来,当用户关闭网页,过三天再打开网页的时候,依然可以看到 A1、A2 躺在购物车里,因为浏览器并不会无缘无故地删除这个Cookie。

借此,就达到里记录用户操作历史的目的了。

Cookie的一些特点。

1.Cookie可以使用 js 在浏览器直接设置(用于记录不敏感信息,如用户名), 也可以在服务端通使用 HTTP 协议规定的set-cookie来让浏览器种下Cookie,这是最常见的做法。

2.每次网络请求 Request headers 中都会带上Cookie。所以如果Cookie太多太大对传输效率会有影响。

3.一般浏览器存储Cookie最大容量为4k,所以大量数据不要存到Cookie。

2.4、FORM 表单

Form表单传值也是通过URL传递参数

通常使用的表单的提交方式主要是:

post和get两种。

两者的区别在于:post方式是把数据内容放在请求的数据正文部分,没有长度的限制;

get方式则是把数据内容直接跟在请求的头部的URL后面,有长度的限制。

而一般在表单的数据提交中,都会选择POST方式,

因为使用GET方法数据是通过URL传递的,在地址栏中会直接看到传递的数据,这样就缺少安全性。

而使用POST传递时,是把提交的数据放置在HTTP包的包体中,地址栏不会看到数据。



3.常见问题

既然有如此多种页面传参的方式。那么问题来就来了,在什么情况下,适合使用以上介绍的传递方式呢?



4.解决方案

在传递少量不涉及隐私的参数时可以使用直接url或者Form的GET方式传递,大量数据可以用POST传递

会话信息等可以用cookie和localStorage,临时数据可用sessionStorage



5.编码实战


URL传参


H5 web storage传参


Cookie传参


6.扩展思考

传参方式的优缺点

6.1、URL传参:

优点:取值方便,可以跨域。

缺点:值长度有限制。

6.2、H5 Web storage:

优点:使用起来非常简单、方便。

缺点:兼容性有点小问题。兼容性: 现代浏览器(firefox safari chrome opera)都支持,IE8以下(不包括IE8)不支持。

6.3、Cookie传参:

优点:兼容性最好,可以在同源内的任意网页内访问,生命期可以设置。

缺点:值长度有限制(存储的容量小),还得注意请求接口时别带到http head。



7.参考文献

参考一:(转)菜鸟教程

参考二:(转)知乎专栏



8.更多讨论

一、为啥需要页面之间传参?

二、除了上述的页面传参方法外,还有哪些方法可以传参?

三、有了页面传参,我们的项目还可以有哪种操作?

详见视频:


JS有哪几种传参方式_腾讯视频

PPT戳这里


感谢大家观看!

今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342

推荐阅读更多精彩内容