欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JavaScript监听手机物理返回键的两种解决方法

程序员文章站 2022-05-26 08:17:42
javascript没有监听物理返回键的api,所以只能使用 popstate 事件监听。 有两个解决办法: 1、返回到指定的页面   &...

javascript没有监听物理返回键的api,所以只能使用 popstate 事件监听。

有两个解决办法:

1、返回到指定的页面    

 pushhistory(); 
    window.addeventlistener("popstate", function(e) { 
      window.location = 'http://www.baidu.com';
    }, false); 
    function pushhistory() { 
      var state = { 
        title: "title", 
        url: "#"
      }; 
      window.history.pushstate(state, "title", "#"); 
    }

2、js文件方法

此声明函数在xback.js文件里有,在app.js里必须再声明一次,不然监听返回事件失败。

/**
 * 使用 html5 的 history 新 api pushstate 来曲线监听 android 设备的返回按钮
 * xback.listen(function(){
    alert('oh! you press the back button');
  });
 */
;!function(pkg, undefined){
  var state = 'x-back';
  var element;
  var onpopstate = function(event){
    event.state === state && fire();
  }
  var record = function(state){
    history.pushstate(state, null, location.href);
  }
  var fire = function(){
    var event = document.createevent('events');
    event.initevent(state, false, false);
    element.dispatchevent(event);
  }
  var listen = function(listener){
    element.addeventlistener(state, listener, false);
  }
  ;!function(){
    element = document.createelement('span');
    window.addeventlistener('popstate', onpopstate);
    this.listen = listen;
    record(state);
  }.call(window[pkg] = window[pkg] || {});
}('xback');

调用方法:

xback.listen(function(){
  alert('back');
});

总结

以上所述是小编给大家介绍的javascript监听手机物理返回键的两种解决方法,希望对大家有所帮助