详解js跨页面传参以及API的解释

简介: 详解js跨页面传参以及API的解释

详解js跨页面传参

前言

还是那句话,搞明白这几个问题。

首先什么是跨页面传参?

其次跨页面传参具体怎么实现?

然后有那些方法?

以及有哪些需要拓展和了解的东西?

什么是跨页面传参?

跨页面传参通常是指在一个页面中通过JavaScript代码传递数据到另外一个页面。这些数据可以是字符串、数字、对象等等,可以用来进行页面跳转、页面渲染和数据处理等操作。跨页面传参本质是什么?

跨页面传参的基本原理是将数据存储在一个变量或对象中,然后在跳转到另外一个页面时将这个变量或对象传递过去。在另外一个页面中,通过JavaScript代码获取这个变量或对象的值,从而完成跨页面传参。既然是先在原来的页面把需要用的数据存先在变量或对象中,在另一个页面接收这个变量或者对象。那么我们的注意力就要放在怎么存?怎么取?这两点问题上。无外乎这几种可能性:

1.其他页面存了数据,但是这个页面取数据的时候出问题了,比如取不出来,或者找不到这个变量。那么病灶就可能是存的时候出问题了。无外乎传参方法错误,以及书写错误所致。

2.上个页面存了数据,但是又在新的页面取不到数据,并且存的方式是正确的。那么病灶就是取的时候出问题了。

3.完全不会存数据,也不会取数据。


常见的跨页面传参方法

URL参数传递

举个栗子:

我们可以在一个页面上使用以下代码将数据作为URL参数传递到另一个页面:

window.location.href = 'page2.html?data=' + data;

在另一个页面上,我们可以使用以下代码获取URL参数:

var data = window.location.search.substring(1).split('=')[1];

这种方法非常简单,但也有一些限制。首先,URL参数的长度有限制,因此不能传递大量的数据。其次,URL参数可以被用户看到,因此不适合传递敏感信息。

你比如说:

我在百度里搜索:爱学习的Akali king

你看域名:这不就是用url传参的吗?

再举个栗子:

// 页面A跳转到页面B并传递参数
var name = 'Tom';
window.location.href = 'pageB.html?name=' + encodeURIComponent(name);
// 页面B获取参数
var params = new URLSearchParams(window.location.search);
var name = params.get('name');
console.log(name); // 输出 'Tom'

需要注意的是,由于URL参数中可能会包含特殊字符,需要使用encodeURIComponent()方法进行编码,以避免传参出错。
localStorage和sessionStorage参数传递

localStorage和sessionStorage是HTML5提供的两种新的存储方式,它们可以在不同的页面之间传递数据。localStorage和sessionStorage都是用来存储数据的浏览器API,并不支持直接传参。但是我们可以通过存储一个JSON对象的方式来传递参数。


你比如说:我们可以把参数封装成一个对象,然后将这个对象转换成JSON字符串,存储到localStorage或sessionStorage中:

// 存储参数
var params = { name: 'Tom', age: 18 };
localStorage.setItem('params', JSON.stringify(params));
// 读取参数
var paramsStr = localStorage.getItem('params');
var params = JSON.parse(paramsStr);
console.log(params.name); // 输出 'Tom'
console.log(params.age); // 输出 18

需要注意的是,JSON.stringify()方法将对象转换成字符串时,如果对象中有函数、undefined、NaN等无法序列化的值,则会被忽略掉。因此,我们需要确保存储的对象中不包含这些值。

Cookie传递

Cookie是一种存储在用户计算机上的数据,它可以在不同的页面之间传递。我们可以使用JavaScript设置Cookie,然后在另一个页面上读取Cookie数据。例如,我们可以在一个页面上使用以下代码设置Cookie:

document.cookie = 'data=' + data;

在另一个页面上,我们可以使用以下代码读取Cookie数据:

var data = document.cookie.split('=')[1];

这种方法可以传递较大的数据,但也有一些限制。首先,Cookie数据存储在用户计算机上,因此用户可以修改Cookie数据。其次,Cookie数据的长度也有限制。

选择合适的方法去完成自己的需求,不可盲目跨页面传参

跨页面传参这个活就算干完了,在本页面取到了其他页面存的东西,那么就可以本页面使用了。在本页面使用这些数据时,无外乎函数之间的传参,这个我已经在之前的文章讲的很清楚了。

具体方法参见

js传参的六种方式

详解javaScript的事件中,复杂数据类型的传参(数组,对象,函数)

详解JavaScript的形参,实参以及传参


经常听到API,那么到底的什么是API?

API(Application Programming Interface,应用程序编程接口)是一组定义了软件系统如何与其他系统进行交互的接口,提供给开发者使用的一些函数、类、方法、协议等,用于访问外部系统或服务的功能。简单点说,API就是一种编程接口,是一种让不同的软件应用程序之间相互通信的方式。


举个栗子,你在使用微信、淘宝等应用的时候,它们提供的许多功能都是通过API来实现的。比如微信提供的获取用户信息、发送消息、支付等功能,淘宝提供的搜索商品、下单、查询订单等功能,都是通过API向外部系统或服务发送请求,获取数据或执行操作。


在前端开发中,我们经常使用浏览器提供的API,比如DOM API、Canvas API、XMLHttpRequest API等,用来操作网页、获取数据、与服务器进行交互等。同时,也可以通过调用第三方API,比如百度地图API、高德地图API、天气查询API等,来获取地图、天气等信息,丰富我们的应用功能。


总之,API是一种接口,是一种规范,定义了软件系统之间如何进行交互,让不同的应用程序之间可以互相调用、交换数据。


相关文章
|
8天前
|
JSON JavaScript API
深入浅出Node.js:从零开始构建RESTful API
【10月更文挑战第39天】 在数字化时代的浪潮中,API(应用程序编程接口)已成为连接不同软件应用的桥梁。本文将带领读者从零基础出发,逐步深入Node.js的世界,最终实现一个功能完备的RESTful API。通过实践,我们将探索如何利用Node.js的异步特性和强大的生态系统来构建高效、可扩展的服务。准备好迎接代码和概念的碰撞,一起解锁后端开发的新篇章。
|
19天前
|
JavaScript 中间件 API
Node.js进阶:Koa框架下的RESTful API设计与实现
【10月更文挑战第28天】本文介绍了如何在Koa框架下设计与实现RESTful API。首先概述了Koa框架的特点,接着讲解了RESTful API的设计原则,包括无状态和统一接口。最后,通过一个简单的博客系统示例,详细展示了如何使用Koa和koa-router实现常见的CRUD操作,包括获取、创建、更新和删除文章。
36 4
|
12天前
|
JavaScript 前端开发 NoSQL
深入浅出:使用Node.js构建RESTful API
【10月更文挑战第35天】在数字时代的浪潮中,后端技术如同海洋中稳固的灯塔,为前端应用提供数据和逻辑支撑。本文旨在通过浅显易懂的方式,带领读者了解如何利用Node.js这一强大的后端平台,搭建一个高效、可靠的RESTful API。我们将从基础概念入手,逐步深入到代码实践,最终实现一个简单的API示例。这不仅是对技术的探索,也是对知识传递方式的一次创新尝试。让我们一起启航,探索Node.js的奥秘,解锁后端开发的无限可能。
|
1月前
|
JSON JavaScript 前端开发
使用JavaScript和Node.js构建简单的RESTful API服务器
【10月更文挑战第12天】使用JavaScript和Node.js构建简单的RESTful API服务器
17 0
|
1月前
|
JSON JavaScript API
Node.js RESTful API
10月更文挑战第8天
14 0
|
9天前
|
JSON API 数据格式
淘宝 / 天猫官方商品 / 订单订单 API 接口丨商品上传接口对接步骤
要对接淘宝/天猫官方商品或订单API,需先注册淘宝开放平台账号,创建应用获取App Key和App Secret。之后,详细阅读API文档,了解接口功能及权限要求,编写认证、构建请求、发送请求和处理响应的代码。最后,在沙箱环境中测试与调试,确保API调用的正确性和稳定性。
|
21天前
|
供应链 数据挖掘 API
电商API接口介绍——sku接口概述
商品SKU(Stock Keeping Unit)接口是电商API接口中的一种,专门用于获取商品的SKU信息。SKU是库存量单位,用于区分同一商品的不同规格、颜色、尺寸等属性。通过商品SKU接口,开发者可以获取商品的SKU列表、SKU属性、库存数量等详细信息。
|
22天前
|
JSON API 数据格式
店铺所有商品列表接口json数据格式示例(API接口)
当然,以下是一个示例的JSON数据格式,用于表示一个店铺所有商品列表的API接口响应
|
1月前
|
编解码 监控 API
直播源怎么调用api接口
调用直播源的API接口涉及开通服务、添加域名、获取API密钥、调用API接口、生成推流和拉流地址、配置直播源、开始直播、监控管理及停止直播等步骤。不同云服务平台的具体操作略有差异,但整体流程简单易懂。
|
12天前
|
JSON API 数据安全/隐私保护
拍立淘按图搜索API接口返回数据的JSON格式示例
拍立淘按图搜索API接口允许用户通过上传图片来搜索相似的商品,该接口返回的通常是一个JSON格式的响应,其中包含了与上传图片相似的商品信息。以下是一个基于淘宝平台的拍立淘按图搜索API接口返回数据的JSON格式示例,同时提供对其关键字段的解释
下一篇
无影云桌面