H5页面跳转与传值

时间:2023-03-09 16:01:39
H5页面跳转与传值

页面之间的跳转经常使用a标签,使用mvc框架的都是通过访问controller的请求方法,返回请求页面。但本次开发,前端与后台完全分离,前端APP使用HBuider来开发,后台数据就无法使用mvc框架访问数据的方法了。

H5提供了本地存储用户浏览数据的方法,早些时候,本地存储使用的是 cookie。但是Web 存储需要更加的安全与快速. 这些数据不会被保存在服务器上,但是这些数据只用于用户请求网站数据上.它也可以存储大量的数据,而不影响网站的性能。

数据以 键/值 对存在, web网页的数据只允许该网页访问使用。

主要使用的是localStorage和sessionStorage对象。 localStorage - 没有时间限制的数据存储; sessionStorage - 针对一个 session 的数据存储(关闭窗口,存储的数据清空)。

1.  localStorage实现方式:

(1)存储:localStorage.setItem("name","张三");

(2)获取数据:var name=localStorage.getItem("name");

(3)移除: localStorage.removeItem("name");

(4)清楚所有:localStorage.clear();

(5)保存非字符串,需要使用JSON转化:

存:oStorage.setItem('data', JSON.stringify(data));  取:var data = JSON.parse(oStorage.getItem('data'));

2.  sesstionStorage的方式与localStorage基本相同:

sessionStorage.setItem("key", "value"); var value = sessionStorage.getItem("key");

3.  与cookie比较:

a. 它存储容量更大 b. 每次请求,cookie都要被传送,浪费带宽,另外,cookie不可以跨域访问

4. 页面跳转举例:

mui页面跳转并传值:

function showDetails(msgSource){ mui.openWindow({ url:viewUrl+"Character1.html", id:"Character1.html", extras:{"companyID":companyID,"msgSource":msgSource,"msg_type":msg_type} }); }

a标签跳转:<a href="'+viewUrl+'Character1.html?msg_source='+data.result[i].msgSource+'"  class="more">

调用方法跳转:</div>'+'<a href="javascripte:;" onclick="javascript:showDetails('+data.result[i].msgSource+')"  class="more">查看详情</a>

页面刷新:window.location.reload();