首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js监听手机端点击物理返回js监听pc端点击浏览器返回

之前在项目中遇到一个问题,就是在微信网页上面本来是有返回按钮的,但是大多数人都为了方便,会使用安卓手机自带的物理返回,这个返回按下后,就会按照你浏览器的栈存储的路径来一层一层返回,就不执行你页面上的那个返回按钮的操作了...; 当onpopstate被触发时,检查event.state是否等于STATE,如果相等,表示页面发生了后退(按下返回或者浏览器的后退按钮),则把这次行为当作是返回被按下了(把点击浏览器的后退按钮也误算进来了...,这时候你就需要再上次那个操作完之后再使用histroy.pushState再写入一次之前写入的那个状态,这样下次会继续监听那个物理返回,否则下次你再点击那个返回的话,就会直接返回浏览器的栈的上一级...不过这个方法有些缺陷: 如果项目本身使用了pushState,则历史记录会有瑕疵(多了一个历史); 浏览器的后退按钮点击以及调用history.back()也会被当成按下了返回。...举个例子: 我在vue的项目中引入xback.js  关于上面在

9.1K10
您找到你想要的搜索结果了吗?
是的
没有找到

thinkphp 如何禁止浏览器缓存

问题 我写了一个礼品兑换功能,但用户兑换完成后,后退又进入兑换页面,如果使得用户使用浏览器自带的后退按钮后退后页面重新读取php代码 解决方案 //设置此页面的过期时间(用格林威治时间表示),只要是已经过去的日期即可...header("Expires: Mon, 26 Jul 1970 05:00:00 GMT"); //设置此页面的最后更新日期(用格林威治时间表示)为当天,可以强制浏览器获取最新资料 header...("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); //告诉客户端浏览器不使用缓存,HTTP 1.1 协议 header("Cache-Control...: no-cache, must-revalidate"); //告诉客户端浏览器不使用缓存,兼容HTTP 1.0 协议 header("Pragma: no-cache"); 最后修改:5年前

1.6K30

JS如何返回异步调用的结果?

JS前端编程与后端编程最大的不同,就是它的异步机制,同时这也是它的核心机制。 为了更好地说明如何返回异步调用的结果,先看三个尝试异步调用的示例吧。...这是由JS的主线程是单线程而决定的,JS代码执行到一定位置的时候,它不能等待,等待意味着用户界面的卡顿,这是用户不能容忍的。...JS采用异步线程优化该场景,当主线程中有异步操作发起时,主线程不会阻塞,会继续向下执行;当异步操作有数据返回时,异步线程会主动通知主线程:“Hi,老大,数据来了,现在要用吗?” “好的!马上给我。”...在了解了JS的异步机制以后,下面看前面三个示例如何正确改写。...这也是一种被称为“异步转同步”的JS编程范式,在前端开发中已被普遍接受。

4.9K40

【干货】JS如何判断用户是否点击浏览器“退回”按钮返回上一个界面?

通过window的popstate事件可以监听history的变化,但是,popstate会在浏览器前进后退操作、history.go/back/forward调用、hashchange的时候被触发,它是一个复合事件...具体我总结为3步: 充实history stack,以提供更多信息让我们可以在用户刷新浏览器的情况下,仍然获得上下页信息关联 为history创建一个私有的记录值,用以区分history当前的state...history是浏览器用户记录用户浏览器历史的全局对象,既然是“浏览历史”,那么就是一组单一数据的列表(有顺序),这个所谓单一数据,就是其内部的state概念,一个state表示用户在浏览一个界面(对应一个...注意,浏览器不会主动帮你记录当前的url,虽然它自己记录在了浏览器内部,你可以通过浏览器的“浏览历史”功能查看,但是,你无法在代码层面直接读取这些历史记录,你只能读取history当前的state,即通过...“只能读取当前的”,也就意味着这是一种栈结构的数据管理,而且,这个栈在用户刷新当前浏览器tab时,仍然是维持的。

5.7K50

js判断页面是否是通过浏览器后退按钮返回打开的

这样子就产生了一个问题,点击身份的时候会生成新的token,但是页面是允许返回的所以url地址栏中的历史token还在,所以就会基于这个token触发请求导致接口报了Token验证失败的错误,一番搜索之后终于找到了解决办法...# 解决方法 利用浏览器的window.performance.navigation.type属性 window.performance.navigation.type window.performance...是W3C性能小组引入的新的API,目前IE9以上的浏览器都支持。...(用户通过刷新,包括JS调用刷新接口等方式访问页面) 2 : TYPE_BACK_FORWARD Navigation where the history handling behavior is set...所以我们只要判断type属性为2时就可以知道页面是通过返回按钮打开的了,然后开头的问题就可以据此加判断来解决token异常了。 ?

16.7K20

如何浏览器里用js解析excel文件

上篇文章给大家介绍了如何借助nodejs平台解析操作excel,今天给大家介绍如何浏览器端使用js解析操作excel。...在文章开始之前我们要搞明白一件事情,那就是在浏览器端用js操作excel主要来做什么呢? 主要做两件事情读和写,对就是这两件事情,在浏览器端针对Excel操作的所有需求无非就是读和写。...那么这里就出现了一个问题,我们如何能拿到excle文件的二进制数据呢? 这里又牵扯出了一个问题,浏览器如何读取excel文件的二进制数据,这里需要用到HTML5规范的一个新特性FileReader。...上执行mozGetAsFile()方法后返回结果。...以上便是浏览器借助js读取excel文件,代码量不多但稍微有点繁琐,涉及到了FileReader这个html5的新特性。

9.9K52

如何用css和js禁止网页选择文字(兼容) 保护版权呢?(附代码)

现在有好多人为了省事直接复制他人的文章,从而损害到别人的利益,那么如何从技术上保护呢? 问: 前端开发css禁止选中文本如何禁止选中文字???...禁止选中的方法很简单,有两种方法:JS和CSS两种 js方法(onselectstart=”return false;) 直接干货 123456789 if(document.all){ document.onselectstart...css方法(user-select) user-select有两个值: none:用户不能选择文本 text:用户可以选择文本 需要注意的是:user-select并不是一个W3C的CSS标准属性,浏览器支持的不完整...,需要对每种浏览器进行调整 123456789101112body{-moz-user-select: none; /*火狐*/-webkit-user-select: none; /*webkit浏览器...*/-ms-user-select: none; /*IE10*/-khtml-user-select: none; /*早期浏览器*/user-select: none;}IE6-9还没发现相关的CSS

2.2K21
领券