从品牌网站建设到网络营销策划,从策略到执行的一站式服务
问题:在项目中,我们常常有需求,当用户在填写表单时,点击返回的时候,我们希望加一个弹窗,确认离开吗,确认将保存为草稿
仁化网站建设公司创新互联,仁化网站设计制作,有大型网站制作公司丰富经验。已为仁化1000+提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的仁化做网站的公司定做!
解决方案:利用 H5的 pushstate(个人理解为增加页面栈)特性与onpopup事件
分析:pushstate 从该方法名我们可以知道 是增加某种状态,会为history对象的length增加长度, 点击返回键的时候会触发onpopup事件(可以联想到 pop其实是数组删除的最后一个元素,符合 ‘栈' 的思想);
onpopup触发返回上一页,而 pushstate仅仅是从url上进行了改变,不会校验url的内容,页面不会改变,加入当前页面为 xxx/b.html,此时pushState(null,null,'a.html')
,可以发现 url变了,而页面的内容并没有改变,我们可以通过这来造成一种无法返回的假象
实施:
//注意:Dialog是一款弹窗的插件 mounted: function() { //当前页面挂载的时候调用 返回键的监听方法 this.listeningBack() } //当页面销毁的时候我们也要将事件监听销毁,以免影响其他内容 destroyed:function(){ window.onpopstate = null }, methods:{ //监听返回键 listeningBack() { var that = this;//window.onpopstate方法指向window,所以要储存一下当前的vue实例 let route = '上一页';//根据业务逻辑的上一页决定 window.onpopstate = function() { //将当前页面window.location.href 放入页面栈当中 history.pushState({}, null, window.location.href); Dialog.alert({ title: '标题', message: '确认返回吗,你所填写的内容将保存为草稿' }).then(() => { that.$router.push({ path:route }) }).catch( console.log('取消返回,留在当前页面') ); } }, }
总结
以上所述是小编给大家介绍的vue中监听返回键问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对创新互联网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图