Uniapp 微信小程序内打开web网页

技术栈:Uniapp + Vue3

简介

实际业务中有时候会需要在本微信小程序内打开web页面,这时候可以封装一个路由页面专门用于此场景。

在路由跳转的时候携带路由参数,拼接上web url,接收页面进行参数接收即可。

实现

webview页面

新建一个路由页面,处理接收到的web url,并使用web-view渲染。

javascript 复制代码
<template>
  <view class="container">
    <web-view :src="externalUrl"></web-view>
  </view>
</template>
   
  <script setup>
import { ref } from "vue";
import { onLoad } from "@dcloudio/uni-app";

const externalUrl = ref("");
onLoad((options) => {
  externalUrl.value = options.url;
});
</script>
   
 <style scoped>
.container {
  width: 100vw;
  height: 100vh;
}
</style>

跳转

在需要触发的页面,路由时带上web url。

javascript 复制代码
/**
* 格式化路由携带的参数
**/
const createQuery = (obj, parentKey = '', keyValueSeparator = '=', pairSeparator = '&') => {
   let queryString = [];
   const that = this;
   Object.keys(obj).forEach(key => {
     const fullKey = parentKey ? `${parentKey}[${key}]` : key;
     if (typeof obj[key] === 'object' && obj[key] !== null && !Array.isArray(obj[key])) {
       queryString.push(this.createQuery(obj[key], fullKey));
     } else {
       queryString.push(`${fullKey}${keyValueSeparator}${obj[key]}`);
     }
   });
   return queryString.join(pairSeparator);
 }
  
  
/**
* 点击跳转web页面
**/
const onClick = () => {
	const params = {
		url: 'https://mp.weixin.qq.com/s/Dq4xx5FUFRB-oJKrwzjewg'
	}
	const url = '/pages/webview/index'
	const query = this.createQuery(params);
    uni.navigateTo({
      url: `${url}?${query}`,
    });
}
相关推荐
腾马科技4 小时前
新版saas餐饮外卖小程序源码/微信/支付宝/抖音/扫码点餐/DIY装修/美团代付/全开源
微信小程序·小程序·点餐小程序
用户904706683578 小时前
uniapp Vue3版本,用pinia存储持久化插件pinia-plugin-persistedstate对微信小程序的配置
前端·uni-app
郑叔敲代码9 小时前
帝国cms 微信小程序的登录逻辑
微信小程序·小程序·notepad++
乔冠宇10 小时前
uniapp创建ts项目tsconfig.json报错的问题
uni-app
细节控菜鸡10 小时前
【2025最新】uniapp 中基于 request 封装实现多文件上传完整指南
uni-app
fakaifa10 小时前
【全开源】企业微信SCRM社群营销高级版系统+uniapp前端
uni-app·开源·企业微信·scrm·源码下载·企业微信scrm
棋子一名12 小时前
跑马灯组件 Vue2/Vue3/uni-app/微信小程序
微信小程序·小程序·uni-app·vue·js
无衣 秦风13 小时前
vue3+hubuilderX开发微信小程序使用elliptic生成ECDH密钥对遇到的问题
微信小程序·小程序
游戏开发爱好者814 小时前
BShare HTTPS 集成与排查实战,从 SDK 接入到 iOS 真机调试(bshare https、签名、回调、抓包)
android·ios·小程序·https·uni-app·iphone·webview
2501_9160088914 小时前
iOS 26 系统流畅度实战指南|流畅体验检测|滑动顺畅对比
android·macos·ios·小程序·uni-app·cocoa·iphone