栈外h5跳转app,否则跳商城下载

本文介绍了如何在端外环境中通过统跳地址唤起已安装的应用,或者引导用户前往应用商城下载。涉及获取统跳地址、应用宝和iOS商店链接,以及异步处理确保流畅体验,同时避免内存泄漏。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

端外在打开h5时,一些情况下需要唤起app。若安装app,则唤起,否则跳转手机商城下载页。

1 获取端外统跳地址

需要找端内开发人员提供,格式大致如下:

/**
 * protocol为统跳协议(每一个app都有特定的protocol)
 * path为app内页面路径(可以为'')
 * params为跳转参数(如:id=123&from=web)
 */
const schemeUrl = `${protocol}://${path}?${params}`

2 获取应用商城地址

const defaultUrl = 'https://a.app.qq.com/o/simple.jsp?pkgname=xxx' // 应用宝地址,也可以是app官方下载地址,用作兜底(http协议的地址)
const iosAppStore = 'https://apps.apple.com/cn/app/idxxx' // ios商店地址

function getAndriShop() { // 获取安卓商城地址
  let hreff = '';
  if (ua.isVivo) {
    hreff = 'vivoMarket://details?id=xxx'
  } else if (ua.isoppo) {
    hreff = 'oppomarket://details?packagename=xxx'
  } else if (ua.isHuawei) {
    hreff = 'appmarket://details?id=xxx'
  } else if (ua.isXiaomi) {
    hreff = 'mimarket://details?id=xxx'
  } else if (ua.isMeizu) {
    hreff = 'mstore://details?id=xxx'
  } else {
    hreff = YYB
  }
function goAppShop() {
	if (ua.ios) {
		window.location.href = iosAppStore // ios商城
		return
	}
	if (ua.qqbrowser) { // 特殊浏览器处理(商店无法跳转)
     	window.location.href = YYB // 应用宝
    	return
  	}
  	window.location.href = getAndriAddr() // android商城
    setTimeout(function() { // 若商城打开失败,跳转应用宝兜底
      window.location.href = YYB // 应用宝
      setTimeout(() => {
        window.close()
      }, 500)
    }, 500)
}

3 具体实现

实现原理:
使用window.location跳转app协议地址,并在之后通过setInterval做异步处理。
如果成功唤起app,则会离开当前页,否则??s后清除计时器并打开商城。
最后通过监听visibilitychange(当前页是否可见),??s内若唤起app,即当前页被隐藏,document.hidden=true,此时清除计时器,防止内存泄漏(不再跳商城)。
代码如下:

const jumpOutOpenApp = () => {
    Toast.info('链接加载中,请稍候', 3)
    const openAppUrl = schemeUrl // 栈外统跳地址
    window.location = openAppUrl // 打开app(如果安装)
    /**
     * 若已经安装,上一步已经完成跳转,后面的代码执行与否不需在意
     * 若没有安装,上一步跳转失败,延迟执行后面的代码
     */
     const initialTime = new Date()
     let counter = 0
     let waitTime = 0
     const checkOpen = setInterval(() => {
     	counter++
      	waitTime = new Date() - initialTime
      	if (waitTime > 3500) {
        	clearInterval(checkOpen)
        	goAppShop()
      	}
      	if (counter < 1000) {
        	return null
      	}
     }, 20)

     document.addEventListener('visibilitychange', () => {
     	const isHidden = document.hidden
      	if (isHidden) {
        	clearInterval(checkOpen)
      	}
	 })
}

也可以利用一些过渡手段,将唤起app和打开商城分成两步,思路如下:
点击 按钮,跳转一个新的页或者在本页面打开一个弹窗(称之为过渡页),过渡页中可以添加下载按钮供用户手动点击跳转商城下载,过渡页在渲染过程中唤醒app(默认操作,用户无感知),能唤醒就直接跳转app,否则停留在过渡页,这种情况等价于未唤醒app,等待用户手动点击跳转商城。

const ModalDown = () => {
	useEffect(() => {
		window.location = openAppUrl // 打开app(如果安装)
	}, [])

	return <div><
		xxx
		<div onClick={goAppShop}>下载app</div>
	/div>
}
### 实现H5页面跳转至荣耀手机应用商店的方法 对于希望从H5页面直接引导用户前往荣耀手机上的应用市场安装特定应用程序的情况,通常有两种主要的技术方案可以选择:URL Scheme 和 Intent 方式。 #### 使用 URL Scheme 方式 当目标设备支持通过预定义的 scheme 来访问第三方应用时,可以构建如下形式的链接: ```html <a href="market://details?id=com.example.package">打开应用市场</a> ``` 此链接尝试利用 `market://` 协议来触发系统默认的应用商店程序,并传递参数 `id` 指定要查找的应用包名。这种方式适用于大多数基于Android系统的智能手机品牌,包括荣耀系列机型[^1]。 然而需要注意的是,在实际开发过程中应当考虑到不同厂商可能对标准协议有所修改或扩展;因此建议开发者查阅官方文档确认是否存在针对荣耀品牌的特殊配置需求。 #### 使用 Intent 方式 另一种更为推荐的方式是采用 Android 平台特有的 intent 机制来进行跨应用交互。这不仅限于启动其他已安装的应用,还可以用来打开应用商店并定位到某款软件的位置。下面是一个具体的 HTML/JavaScript 示例代码片段展示如何实现这一点: ```javascript function openHuaweiAppStore(packageName) { var url = 'intent://' + packageName + '#Intent;scheme=market;action=android.intent.action.VIEW;end'; window.location.href = encodeURI(url); } // 调用函数传入想要推广的应用包名作为参数 openHuaweiAppStore('com.example.package'); ``` 上述 JavaScript 函数构造了一个符合 Android intent URI 规范的字符串,并将其赋值给当前窗口位置属性以发起请求。这里特别指定了 `scheme=market` 表明意图访问华为自家的应用商店服务[^3]。 为了确保最佳用户体验以及兼容性考虑,可以在网页加载初期检测用户的终端环境(如判断是否为荣耀/Huawei 设备),再决定采取哪种策略最为合适。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值