位置: 编程技术 - 正文

js点击返回跳转到指定页面实现过程(js点击按钮返回前一个页面)

编辑:rootadmin

推荐整理分享js点击返回跳转到指定页面实现过程(js点击按钮返回前一个页面),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js点击按钮跳转到指定页面,js点击返回顶部,js点击按钮跳转到指定页面,js页面返回,js点击按钮跳转到指定页面,js点击按钮跳转到指定页面,js点击按钮跳转到指定页面,js返回跳转指定页面,内容如对您有帮助,希望把文章链接给更多的朋友!

这个功能之前有简单的带过,这次详细的讲解下原理和存在的问题(由于是运用html5的新API 所以有兼容问题,推荐移动端使用该方法)。

功能描述:

在浏览器中新建标签页并指定一个网址,网页加载完毕后,正常流程下是不允许点击返回的。因为当前标签页的相关历史记录是没有的,所以没有记录可以返回。

应客户要求,需要在这种情况下,给他的历史记录里添加一个链接(比如首页),这样在新打开的页面,点击返回就可以跳转到首页,让用户看到系统的各种功能,推广平台。

一、知识要点

HTML5引进了history.pushState()方法和history.replaceState()方法,它们允许你逐条地添加和修改历史记录条目。这些方法可以协同window.onpopstate事件一起工作。

案例:假设 将执行如下JavaScript代码:

这将让浏览器的地址栏显示 object)包含stateObj的一个拷贝。该页面看起来像foo.html,尽管页面内容可能在popstate事件中被修改。

如果我们再次点击后退按钮,URL将变回 文档将触发另一个popstate事件,这次的状态对象为null。回退同样不会改变文档内容。

pushState()方法pushState()有三个参数:一个状态对象、一个标题(现在会被忽略),一个可选的URL地址。下面来单独考察这三个参数的细节:

状态对象(state object) — 一个JavaScript对象,与用pushState()方法创建的新历史记录条目关联。无论何时用户导航到新创建的状态,popstate事件都会被触发,并且事件对象的state属性都包含历史记录条目的状态对象的拷贝。

任何可序列化的对象都可以被当做状态对象。因为FireFox浏览器会把状态对象保存到用户的硬盘,这样它们就能在用户重启浏览器之后被还原,我们强行限制状态对象的大小为k。如果你向pushState()方法传递了一个超过该限额的状态对象,该方法会抛出异常。如果你需要存储很大的数据,建议使用sessionStorage或localStorage。

标题(title) — FireFox浏览器目前会忽略该参数,虽然以后可能会用上。考虑到未来可能会对该方法进行修改,传一个空字符串会比较安全。或者,你也可以传入一个简短的标题,标明将要进入的状态。

地址(URL) — 新的历史记录条目的地址。浏览器不会在调用pushState()方法后加载该地址,但之后,可能会试图加载,例如用户重启浏览器。新的URL不一定是绝对路径;如果是相对路径,它将以当前URL为基准;传入的URL与当前URL应该是同源的,否则,pushState()会抛出异常。该参数是可选的;不指定的话则为文档当前URL。

注意: 在 Gecko 2.0 (Firefox 4 / Thunderbird 3.3 / SeaMonkey 2.1) 至 Gecko 5.0 (Firefox 5.0 / Thunderbird 5.0 / SeaMonkey 2.2) 中,传入的对象使用JSON来进行序列化。从 Gecko 6.0 (Firefox 6.0 / Thunderbird 6.0 / SeaMonkey 2.3)开始,对象使用结构化拷贝算法来进行序列化。这将允许更多类型的对象能够安全传入。某种意义上,调用pushState()有点类似于设置window.location='#foo',它们都会在当前文档内创建和激活新的历史记录条目。但pushState()有自己的优势:

js点击返回跳转到指定页面实现过程(js点击按钮返回前一个页面)

1、新的URL可以是任意的同源URL,与此相反,使用window.location方法时,只有仅修改 hash 才能保证停留在相同的document中。

2、根据个人需要来决定是否修改URL。相反,设置window.location='#foo',只有在当前hash值不是foo时才创建一条新历史记录。

3、你可以在新的历史记录条目中添加抽象数据。如果使用基于hash的方法,你只能把相关数据转码成一个很短的字符串。

注意pushState()方法永远不会触发hashchange事件,即便新的地址只变更了hash。

popstate事件每当激活的历史记录发生变化时,都会触发popstate事件。如果被激活的历史记录条目是由pushState所创建,或是被replaceState方法影响到的,popstate事件的状态属性将包含历史记录的状态对象的一个拷贝。

replaceState()方法history.replaceState()操作类似于history.pushState(),不同之处在于replaceState()方法会修改当前历史记录条目而并非创建新的条目。

当你为了响应用户的某些操作,而要更新当前历史记录条目的状态对象或URL时,使用replaceState()方法会特别合适。

二、实现思路1.利用popstate事件,监听点击返回事件。

2.触发事件时,判断当前页面的历史记录 是否有页面可以返回。

3.如果没有页面可以返回,则插入两条记录:

1)、指定的跳转页面。

2)、空记录。(使当前页面不发生变化)

三、实现方法

判断当前history中的记录个数,由于页面加载的时候,浏览器会自动push进一个记录。所以要判断长度是否小于2.

塞进的state对象是为了获取对应的url链接。注意点:第一个pushState我将跳转url放进state对象 方便跳转操作。第二个参数没有实际意义,因为现在的浏览器基本不适用这个参数。第三个参数是会替换当前地址栏的链接的,但是页面不会发生跳转。(我之前犯了个错误,将第三个参数设置为首页链接,导致了地址栏更改为首页链接,以至于在当前页的链接 都以首页为基础进行跳转,导致页面的所有链接都跳转错误了。)

这段代码放置在页面的ready事件中执行,延迟毫秒是为了将操作滞后,防止与系统pop事件冲突。if语句为了判断 history是否存在state对象,因为只有满足我们要求的记录才会有我们添加的state对象 所以 根据这点可以进行页面的跳转操作。这样就可以实现我们想要的效果。 四、写在最后缺点: 1. 很明显,就如开头提到的。只适合支持html5的浏览器使用。 2.由于插进了两条记录 ,所以 类似于 微信这种移动端的返回,需要再点击两次返回,才能推出页面,回到微信聊天窗口,用户体验不好。

总结:这种方法 一定还可以优化和完善,只是目前我的实力不足,还不足以完善到完美的程度。

希望看到这篇文章的朋友可以得到一些启发,或者是有更好的方法实现。

深入浅析JavaScript中的constructor 定义和用法constructor属性返回对创建此对象的数组函数的引用。语法object.constructorconstructor,构造函数,对这个名字,我们都不陌生,constructor始终指向创

javascript+HTML5 Canvas绘制转盘抽奖 之前做过的项目中,有需要抽奖转盘功能的。项目已经完工一段时间了,也没出现什么严重的bug,所以现在拎出来分享给大家。功能需求1、转盘要美观

浅析JavaScript中浏览器的兼容问题 浏览器兼容性问题是在实际开发中容易忽略而又最重要的一部分。我们在讲老版本浏览器兼容问题之前,首先要了解什么是能力检测,它是来检测浏览

标签: js点击按钮返回前一个页面

本文链接地址:https://www.jiuchutong.com/biancheng/373474.html 转载请保留说明!

上一篇:javascript html5摇一摇功能的实现

下一篇:深入浅析JavaScript中的constructor(java script教程)

  • 长租公寓 税费
  • 实收资本印花税是营业账簿吗
  • 合同取得成本属于
  • 什么叫残保金减免
  • 增值税发票税控开票软件打不开
  • 新会计准则下具体会计准则对银行的影响不包括
  • 异地施工需要办理什么手续
  • 增值税属于会计科目的什么
  • 非同一控制下的企业合并采用成本法
  • 应取得未取得发票
  • 小微企业享受减免税政策
  • 房屋过户收费标准
  • 赠送车子需要过户吗
  • 货物的运输费用怎么算
  • 应缴纳企业所得税税额怎么算
  • 分包工程款税率
  • 回拨工费经费怎么做会计分录?
  • 本月完工产品的会计分录
  • 回购库存股所有者权益会发生变化吗
  • 预收房款发票开具需要注意哪些?
  • 开办公用品发票需要清单吗
  • 增值税专用发票电子版
  • 民非企业补贴收入要缴纳增值税会计分录怎么写?
  • 土地房产税征收范围
  • 白酒的消费税怎样计算
  • 加速折旧税收优惠
  • 企业将自产产品发放给职工作为福利
  • 金融行业小规模纳税人税率
  • 个体户开发票要交税吗
  • 分期收款什么时候交税
  • 现金净流量正常值
  • 税务局减免的税金会计分录
  • 小规模公司税控盘维护费会计分录
  • 施工企业代甲方购材料的账务处理?
  • 把管理费用记到什么科目
  • 大学食堂外包的优点与缺点
  • 招投标费用如何收取
  • 非营利组织一般纳税人会计准则
  • 对公账户转私人账户手续费多少
  • deskrun.exe是什么东西
  • 留底的进项税额记哪儿?
  • Yii使用技巧大汇总
  • php image
  • vue3框架的优点
  • 税务新政策解读
  • php正则表达式实例
  • php中哪个命令用来删除当前目录
  • 企业固定资产账户2019年6月初借方余额5000000元
  • 建筑工程增值税怎么算
  • 公立医院增值税抵扣
  • 应税货物及劳务无法录入
  • 股东分红会计分录案例
  • 什么是其他综合收益,包括哪些内容
  • phpcms教程
  • 其他综合收益在利润表的哪个位置哪里
  • 公司过年买的红包封壳怎么做账
  • 退税没有退的部分怎么做账
  • 小企业一年需要缴纳多少税
  • 受托代销商品的手续费计入什么科目
  • PostgreSQL 安装和简单使用第1/2页
  • 以前年度损益调整借贷方向
  • 累计摊销的会计分录有哪些
  • 外聘人员个人简历
  • 还账准备计提方法
  • 一般纳税人主表中的25是怎么来的
  • 技术咨询服务开票代码
  • 费用利润率的意思
  • 租房买的中央空调怎么用
  • mysql的索引实现原理
  • mac设置启动系统
  • unity软件设计
  • python使用mysql数据库示例代码
  • Node.js中child_process实现多进程
  • android 侧滑页面
  • javascript如何定义一个函数
  • js中如何在div里写入内容
  • python百分数运算怎么写
  • 企业年金需要个人财产申报
  • 没有单位怎么交职工养老保险
  • 国内海运费的运价表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设