当前位置: 移动技术网 > IT编程>开发语言>JavaScript > JavaScript监听手机物理返回键的两种解决方法

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

2017年12月12日  | 移动技术网IT编程  | 我要评论

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监听手机物理返回键的两种解决方法,希望对大家有所帮助

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网