uniappH5跳转小程序

1. 获取 JS-SDK 文件

1.官方 CDN(推荐)

在根目录index.html中引入jssdk

复制代码
<script src="https://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script>
2.npm 包
复制代码
npm install weixin-js-sdk

通过 ES Module 导入

复制代码
import wx from 'weixin-js-sdk'

2.确认 wx 对象存在后再使用

javascript 复制代码
// 推荐写法
if (window.wx && window.wx.miniProgram) {
    window.wx.miniProgram.navigateTo({
	    url: "",
    });
} else {
    console.log('当前不在微信小程序 webview 中,或 SDK 未加载')
}

注:不要使用wx.miniProgram.navigateTo("目标地址")

wx.navigateTo 中,url 参数需要用对象形式包裹,即使只提供一个参数

如果window.wx.miniProgram获取不到为undefined

可能原因:

1.使用的JS-SDK版本不对:旧版本可能没有暴露miniProgram,或者需要特定环境。通 常微信JS-SDK jweixin-1.6.0.js 是包含miniProgram的。但可能被某些构建工具或CDN修改了

2.页面不是在微信小程序webview中运行:window.wx.miniProgram只有在微信小程序webview环境中才会被注入,普通浏览器或非微信环境下,该属性不存在

3.使用了错误的对象

解决方式:

1.确认当前页面确实在微信小程序的webview中运行

2.检查是否由于某些打包工具(如webpack)导致wx对象被封装或修改。尝试直接使用wx.miniProgram而不是window.wx.miniProgram

3.使用官方推荐的方式:if (typeof wx !== 'undefined' && wx.miniProgram)或者检查window.__wxjs_environment === 'miniprogram'

推荐通过 window.__wxjs_environment 来判断

javascript 复制代码
if (window.__wxjs_environment === 'miniprogram') {
  // 肯定在小程序 web-view 中
  wx.miniProgram.navigateTo({ url: "" })
} else {
  console.log('当前不在小程序 web-view 中')
}

使用 wx.miniProgram 直接尝试

javascript 复制代码
if (typeof wx !== 'undefined' && typeof wx.miniProgram !== 'undefined') {
  wx.miniProgram.navigateTo({ url: '' })
}

延迟获取

javascript 复制代码
etTimeout(() => {
  if (window.wx && window.wx.miniProgram) {
    // 跳转
  } else {
    console.log('未检测到小程序环境')
  }
}, 500)

如果确认后还获取不到

可能原因:

1.使用最新版本sdk 1.6.0 https://res.wx.qq.com/open/js/jweixin-1.6.0.js

2.小程序基础库太低 确保小程序基础库在 2.4.0 以上

如果window.__wxjs_environment为miniprogram但是wx.miniProgram 为 undefined

说明微信客户端虽然标识了小程序环境,但 JS-SDK 中的 miniProgram 属性没有被正确地注入或覆盖。

解决方法:

重新加载sdk

javascript 复制代码
// 先移除已有的 wx 对象
onload(){
    delete window.wx
    // 重新动态创建 script 标签加载
    var script = document.createElement('script')
    script.src = 'https://res.wx.qq.com/open/js/jweixin-1.6.0.js'
    document.head.appendChild(script)
}

3.完整代码

H5

javascript 复制代码
<template>
    <view>
        <view @click="btnGo">跳转</view>
    </view>
</template>
<script>
    onLoad() {
	    // 尝试重新加载
	    var s = document.createElement('script')
	    s.src = 'https://res.wx.qq.com/open/js/jweixin-1.6.0.js'
	    document.head.appendChild(s)
    },
    methods:{
        btnGo(){
            wx.miniProgram.navigateTo({
			    url: "目标地址",
		    });
        }
    }
</script>

小程序

javascript 复制代码
<template>
    <view>
        <web-view src="你的url"></web-view>
    </view>
</template>
相关推荐
kyriewen5 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒6 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
小林攻城狮6 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦6 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer7 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队7 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY7 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_7 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏8 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
SkyWalking中文站8 小时前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控