移动开发平台 mPaaS 回退

By | 2021年4月23日

用户点击导航栏左上角返回按钮或者 Android 设备的物理返回键时,页面将会收到此事件(back)。

如果在事件的处理函数中调用了 event.preventDefault(),容器将忽略 backBehaviour,JS 需要负责回退或做其他操作。

注意

  • 对于 iOS 端侧滑返回,由于手势操作具有可中途撤销的特性,故无法触发 back 事件。
  • 容器内部有保护机制,如果用户多次重复点击返回按钮依然未能退出当前页,将会触发强制退出,忽略 preventDefault

back 接口的使用方法

  
  1. // 首先屏蔽默认行为,然后调用页面跳转 API 进行手动控制
  2. document.addEventListener('back', function(e) {
  3. e.preventDefault();
  4. console.log('do something...')
  5. AlipayJSBridge.call('popWindow');
  6. }, false);

代码示例

  • 点击回退跳转到指定页面:

        
    1. <h1>请点击左上角返回按钮</h1>
    2. <p>点击后会跳回到淘宝页面</p>
    3. <script>
    4. // 注意:如果自定义了 back,并使用了 location.href 去跳到指定的地址,需要包装一个 setTimeout 以保证不会阻塞客户端线程。
    5. document.addEventListener('back', function(e) {
    6. e.preventDefault();
    7. setTimeout(function() {
    8. location.href = "https://m.taobao.com"
    9. }, 10);
    10. }, false);
    11. </script>
  • 点击回退弹出确认框:

        
    1. <h1>请点击左上角返回按钮</h1>
    2. <script>
    3. document.addEventListener('back', function(e) {
    4. e.preventDefault();
    5. AlipayJSBridge.call('confirm', {
    6. title: '亲',
    7. message: '确定要退出吗',
    8. okButton: '确定',
    9. cancelButton: '算了'
    10. }, function(e) {
    11. if (e.ok) {
    12. AlipayJSBridge.call('popWindow');
    13. }
    14. });
    15. }, false);
    16. </script>

请关注公众号获取更多资料

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注