h5页面内嵌到app,解决ios无法使用左右侧滑返回上一页

背景:vue+vant组合开发的h5页面,嵌入多个app,其中安卓手机都可实现侧滑返回上一页,而苹果端不行,app本身不展示title顶部的返回箭头。

解决办法:判断机型,处理ios端监听左右滑动事件,结合transition实现滑动返回

代码:

javascript 复制代码
//app.vue文件中

<template>
    <div id="app" class="app-content">
        <transition :name="transitionName" @before-enter="beforeEnter" @enter="enter">
        <router-view/>
        </transition>
    </div>
</template>

<script>
export default {
    name: 'App',
    components: {},
    props: {},
    data() {
        return {
       transitionName: '', // 过渡动画的名称
      startPosition: { x: 0, y: 0 }, // 手势开始时的位置
        };
    },
    mounted() {
        document.getElementById('loading').style.display = 'none';
    },
    methods: {
        beforeEnter() {
      // 禁用页面切换动画
      this.transitionName = '';
    },
    enter(el, done) {
        console.log('当前是ios',os.iphone)
        if(os.iphone){//此处判断我的在js文件中
            // 监听touchstart事件
      el.addEventListener('touchstart', (event) => {
        this.startPosition.x = event.touches[0].pageX;
        this.startPosition.y = event.touches[0].pageY;
      });

      // 监听touchend事件
      el.addEventListener('touchend', (event) => {
        const endPosition = {
          x: event.changedTouches[0].pageX,
          y: event.changedTouches[0].pageY,
        };

        // 计算手势滑动的距离
        const deltaX = endPosition.x - this.startPosition.x;
        const deltaY = endPosition.y - this.startPosition.y;

        // 判断滑动方向与滑动距离是否符合返回操作的条件
        if (Math.abs(deltaX) > Math.abs(deltaY) && Math.abs(deltaX) > 30) {
          if (deltaX > 0) {
            // 向右滑动,执行返回上一页的操作
            this.transitionName = 'slide-right';
            this.$router.go(-1); // 是否返回上一页可以自行修改
            return;
          } else if (deltaX < 0) {
            // 向左滑动,执行返回下一页的操作
            this.transitionName = 'slide-left';
            this.$router.go(-1); // 是否返回上一页可以自行修改
            return;
          }
        }

        // 其他情况,继续执行页面切换动画
        this.transitionName = 'slide-left';
        done();
      }); 
        }else{
             // 禁用页面切换动画
      this.transitionName = '';
        }
     
    },
    }
};
</script>

<style lang='less'>
@import url('./style/icon/iconfont.less');
@import url('./style/mixins.less');
.slide-right-enter-active,
.slide-left-enter-active {
  transition: transform 0 ease; // 过渡动画的时间和缓动函数可以根据需求进行调整
}

.slide-right-enter,
.slide-right-leave-active,
.slide-left-enter,
.slide-left-leave-active {
  transform: translateX(100%); // 初始位置设置在页面右侧以实现侧滑效果
}

.slide-right-leave,
.slide-left-leave-to {
  transform: translateX(-100%); // 离开时的目标位置设置在页面左侧以实现侧滑效果
}
</style>

单独js文件中判断机型-自取:

javascript 复制代码
//获取浏览器类型
var ua = navigator.userAgent;
//获取机型判断
var os = {};
var android = ua.match(/(Android);?[\s\/]+([\d.]+)?/);
var ipad = ua.match(/(iPad).*OS\s([\d_]+)/);
var iphone = !ipad && ua.match(/(iPhone\sOS)\s([\d_]+)/);
var ipod = ua.match(/(iPod)(.*OS\s([\d_]+))?/);
if (android) os.android = true;
if (iphone && !ipod) os.ios = os.iphone = true;
相关推荐
叽哥3 小时前
Flutter Riverpod上手指南
android·flutter·ios
用户091 天前
SwiftUI Charts 函数绘图完全指南
ios·swiftui·swift
YungFan1 天前
iOS26适配指南之UIColor
ios·swift
权咚2 天前
阿权的开发经验小集
git·ios·xcode
用户092 天前
TipKit与CloudKit同步完全指南
ios·swift
法的空间2 天前
Flutter JsonToDart 支持 JsonSchema
android·flutter·ios
2501_915918412 天前
iOS 上架全流程指南 iOS 应用发布步骤、App Store 上架流程、uni-app 打包上传 ipa 与审核实战经验分享
android·ios·小程序·uni-app·cocoa·iphone·webview
00后程序员张2 天前
iOS App 混淆与加固对比 源码混淆与ipa文件混淆的区别、iOS代码保护与应用安全场景最佳实践
android·安全·ios·小程序·uni-app·iphone·webview
Magnetic_h3 天前
【iOS】设计模式复习
笔记·学习·ios·设计模式·objective-c·cocoa
00后程序员张3 天前
详细解析苹果iOS应用上架到App Store的完整步骤与指南
android·ios·小程序·https·uni-app·iphone·webview