在移动互联网蓬勃发展的今天,很多开发者会选择使用 UniApp 来开发多端应用,尤其是 H5 端,因其无需下载安装即可访问的特性,深受用户喜爱。但 UniApp H5 应用在 PC 端直接打开时,往往会因为屏幕尺寸的巨大差异,导致界面被拉伸、布局错乱,影响用户体验。

今天,我就来分享一个 UniApp H5 适配不同设备的解决方案,通过巧妙的页面跳转和布局设计,让你的 H5 应用在 PC 端也能拥有良好的展示效果

方案核心思路

我们的目标是:当用户在 PC 端(或大屏幕设备)访问 H5 应用时,自动跳转到一个模拟手机端展示的页面;而在移动设备上,则正常显示 H5 页面。

这个方案主要通过两个部分来实现:

  1. app.vue 中的页面跳转逻辑
  2. 专门为 PC 端准备的 pc.html 页面

具体实现步骤

第一步:在 app.vue 中添加设备判断与跳转逻辑

在 UniApp 项目的 app.vue 文件中,我们可以利用 onShow 生命周期函数,在页面显示时进行设备信息的判断,并根据判断结果决定是否跳转到 PC 端专用页面。

onShow: function() {console.log('App Show')// #ifdef H5uni.getSystemInfo({success(e) {/* 窗口宽度大于420px且不在PC页面且不在移动设备时跳转至 PC.html 页面 */if (e.windowWidth > 420 &&!window.top.isPC &&!/iOS|Android/i.test(e.system)) {// 跳转到PC端专用页面window.location.pathname = "/static/html/pc.html";}},});// #endif
}
第二步:创建 PC 端专用页面 pc.html

在项目的 static 目录下新建 html 文件夹,并在其中创建 pc.html 文件,内容如下:

<!DOCTYPE html>
<html lang=zh-CN><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1"><title></title><meta name="Copyright" content="helang"><meta name="keywords" content=""><meta name="description" content=""><style type="text/css">body{margin: 0;background-color:  #f5f5f5;}iframe{width: 375px;height: 667px;background-color: #fff;box-sizing: border-box;border: none;}@media screen and (min-width: 450px) {iframe {position: fixed;top: 0;right: 0;bottom: 0;left: 0;margin: auto;border: 1px solid #f5f5f5;border-radius: 4px;}}</style><script type="text/javascript">window.isPC = true; // 标识当前为PC页面window.onload = function(){/* 监听电脑浏览器窗口尺寸改变,小于等于420px时跳回H5主页面 */if(window.innerWidth <= 420){window.location.pathname = '/';}}</script></head><body><iframe src="/" id="iframe"></iframe><script src="https://pv.sohu.com/cityjson?ie=utf-8"></script><script type="text/javascript">var Ip=returnCitySN['cip']localStorage.setItem('Ip', Ip)</script></body>
</html>

实现效果

  • 当用户在 PC 端(大屏幕设备)访问你的 UniApp H5 应用时,会自动跳转到pc.html,看到一个居中显示的、模拟手机效果的应用界面。
  • 当用户在移动设备(iOS/Android)访问时,会正常显示 H5 应用。
  • 当用户在 PC 端调整浏览器窗口大小,使其宽度小于等于 420px 时,会自动跳回正常的 H5 页面。

使用注意事项

  1. 路径问题:确保 app.vue 中跳转的路径 /static/html/pc.html 与 pc.html实际存放的路径一致。如果你的项目有特殊的部署路径,可能需要相应调整。
  2. iframe 内容:pc.html 中 iframe 的 src 属性设置为/,适用于项目部署在根目录的情况。如果你的项目部署在子目录,需要修改为对应的路径。
  3. 样式微调:可以根据自己的需求调整 pc.html 中的 CSS 样式,比如 iframe的大小、边框样式、背景色等,使其更符合你的应用风格。
  4. IP 获取:搜狐的 IP 获取接口是免费的,但可能存在不稳定性。如果对 IP 获取有更高要求,可以考虑使用其他更可靠的接口。

总结

通过这种方式,我们可以很巧妙地解决 UniApp H5 应用在 PC 端展示效果不佳的问题。核心思路是通过设备判断和页面跳转,在 PC 端用一个模拟手机的 iframe 来展示应用,既保证了开发效率(无需单独开发 PC 端),又提升了用户体验。

当然,这种方案更适合一些对 PC 端体验要求不是特别高,或者主要用户群体还是在移动端的应用。如果你的应用需要在 PC 端有更完善的体验,那么开发专门的 PC 端页面会是更好的选择。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/90834.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/90834.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/90834.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【MySQL#4】函数 复合查询 内外连接

&#x1f4c3;个人主页&#xff1a;island1314 ⛺️ 欢迎关注&#xff1a;&#x1f44d;点赞 &#x1f442;&#x1f3fd;留言 &#x1f60d;收藏 &#x1f49e; &#x1f49e; &#x1f49e; 生活总是不会一帆风顺&#xff0c;前进的道路也不会永远一马平川&#xff0c;如何面…

C++常见面试题之一

一、语言基础与内存管理const与constexpr的区别&#xff1f;应用场景&#xff1f; const&#xff1a;运行时常量&#xff0c;修饰变量/函数不可修改。constexpr&#xff1a;编译期常量&#xff08;C11&#xff09;&#xff0c;用于优化计算&#xff08;如数组大小&#xff09;。…

Golang 语言中的指针介绍

介绍&#xff1a;指针式一种数据类型&#xff0c;用来存储值的内存地址&#xff0c;为了便于理解&#xff0c;我们也可以把指针未内存地址&#xff0c;指针类型只占用内存4个或 8 个字节&#xff0c;在Golang 语言中&#xff0c;类型名称加 * 表示改类型的指针类型。指针类型变…

Flink 状态管理设计详解:StateBackend、State、RocksDB和Namespace

为什么需要 StateBackend&#xff1f;—— 职责分离原则我们可以用一个银行的例子来类比&#xff1a;State (如 ValueState, ListState) 就像是你的银行卡。AbstractKeyedStateBackend 就像是银行的整个后台系统&#xff08;包括总服务器、数据库、风控系统、会计系统等&#x…

橱柜铰链的革命:炬森精密如何以创新科技重塑家居体验

在现代化家居设计中&#xff0c;橱柜不仅是存储空间的核心&#xff0c;更是生活品质的象征。而作为橱柜的“关节”&#xff0c;橱柜铰链的性能直接影响着日常使用的便捷性、安全性和耐久性。然而&#xff0c;许多消费者在橱柜使用中常遭遇噪音干扰、频繁松动或早期损坏等痛点&a…

医疗系统国产化实录:SQL Server国产替代,乙方保命指南

医疗行业的SQL Server替代&#xff0c;和普通业务系统完全不是一个量级——医嘱逻辑嵌套几十层存储过程、收费结算小数点错位能引发医患纠纷、电子病历查询慢一秒医生直接拍桌子。作为被按在手术台上的乙方PM&#xff0c;实测四款主流国产库后&#xff0c;掏心窝子说句实话&…

WAIC 2025 盛大启幕,深思考邀您解锁端侧 AI 新可能​!

2025 世界人工智能大会今日正式启幕&#xff0c;深思考人工智能&#xff08;iDeepWise&#xff09;携端侧多模态大模型技术成果登陆展会&#xff0c;与行业伙伴共探端侧 AI 发展新机遇。作为专注于类端侧多模态大模型领域的创新力量&#xff0c;深思考此次重点展示了 iDeepWise…

MySQL相关概念和易错知识点(2)(表结构的操作、数据类型、约束)

目录1.表结构的操作&#xff08;1&#xff09;增加表&#xff08;2&#xff09;查看库中所有的表&#xff08;3&#xff09;查看表每个列的约束&#xff08;4&#xff09;删除整张表&#xff08;5&#xff09;删除某个具体的列&#xff08;6&#xff09;增加某个具体的列&#…

1. Qt多线程开发

目录方法1.继承QThread使用案例总结方法2.将qobject对象moveToThread&#xff08;官方推荐&#xff09;使用案例总结方法3.QRunnable QThreadPool使用案例总结方法4.快速线程QtConcurrentQFutureWatcher使用案例总结代码下载方法1.继承QThread 需要实现QThread的抽象函数run …

ARM入门学习方法分享

首先认识什么是ARM?ARM公司简介ARM是Advanced RISC Machines的缩写&#xff0c;它是一家微处理器行业的知名企业&#xff0c;该企业设计了大量高性能、廉价、耗能低的RISC &#xff08;精简指令集&#xff09;处理器。 1985年第一个ARM原型在英国剑桥诞生。公司的特点是只设计…

基于springboot的在线数码商城/在线电子产品商品销售系统的设计与实现

用户&#xff1a;数码产品&#xff0c;限时秒杀&#xff0c;种草分享&#xff0c;新品资讯&#xff0c;留言板&#xff0c;订单管理&#xff0c;在线客服&#xff0c;购物车&#xff0c;个人中心管理员&#xff1a;个人中心&#xff0c;用户管理&#xff0c;数码分类管理&#…

Zookeeper学习专栏(十):核心流程剖析之服务启动、请求处理与选举协议

文章目录前言一、服务端启动流程1.1 启动入口类&#xff1a;QuorumPeerMain1.2 集群模式启动核心&#xff1a;runFromConfig1.3 QuorumPeer线程核心逻辑&#xff1a;run()1.4 关键子流程&#xff1a;数据恢复1.5 关键设计要点二、请求处理链&#xff08;责任链模式&#xff09;…

网络基础19--OSPF路由业务多区域

一、OSPF多区域必要性单区域问题&#xff1a;LSDB庞大 → 内存占用高&#xff0c;SPF计算开销大LSA洪泛范围广 → 拓扑变化影响全域无法路由汇总 → 路由表膨胀&#xff0c;查找效率低2. 多区域优势&#xff1a;1. 划分区域&#xff1a;独立LSDB&#xff0c;缩小数据库规模2. 限…

MFC扩展库BCGControlBar Pro v36.2新版亮点:图形管理器等全新升级

BCGControlBar库拥有500多个经过全面设计、测试和充分记录的MFC扩展类。 我们的组件可以轻松地集成到您的应用程序中&#xff0c;并为您节省数百个开发和调试时间。 BCGControlBar专业版 v36.2已全新发布了&#xff0c;在这个版本中添加了一个新的扩展器控件、改进了网格和报表…

QT开发---网络编程上

Qt Network 模块Qt Network 模块提供了丰富的类用于实现各种网络通信功能&#xff0c;涵盖 TCP、UDP、HTTP、FTP 等多种协议。 Qt 网络类均为异步操作&#xff0c;通过信号槽处理结果&#xff0c;避免阻塞 UI 线程。在使用QT进行网络编程之前&#xff0c;就必须在 CMakeLists.t…

[spring6: Mvc-函数式编程]-源码解析

接口 ServerRequest public interface ServerRequest {HttpMethod method();URI uri();UriBuilder uriBuilder();default String path() {return requestPath().pathWithinApplication().value();}default RequestPath requestPath() {return ServletRequestPathUtils.getPar…

Linux DNS 服务器正反向解析

一、环境说明与准备工作 1.基础信息 本次实验用两台 Linux 主机&#xff0c;分别作为 DNS 服务端和客户端&#xff0c;具体信息如下&#xff1a;服务端IP客户端IP网址192.168.120.130192.168.120.128www.zy.com2.准备工作 关闭安全软件&#xff1a;服务端和客户端都要关闭防火墙…

历史数据分析——中证旅游

中证旅游板块走势从月线级别来看2015年5月到2024年9月&#xff0c;月线上走出了一个震荡中枢的月线级别下跌段&#xff1b;目前月线级别底部放巨量&#xff0c;总体还在底部震荡&#xff0c;后续上涨的概率较大。从周线级别来看从2022年12月到2024年9月整体是下跌走势&#xff…

OpHReda精准预测酶最佳PH

1.显著改进&#xff1a;OpHReda通过检索嵌入数据增强机制&#xff0c;显著提高了酶最佳pH预测的准确性&#xff0c;相比现有方法提升了55%的F1分数。2.多尺度残差轻注意力模块&#xff1a;该模块结合了残差学习和多尺度特征提取&#xff0c;增强了模型对酶序列中残差级信息的捕…

醫護行業在未來會被AI淘汰嗎?

隨着AI的迅速發展&#xff0c;似乎所有職業都有被AI替代的風險&#xff0c;那麼醫療領域作為一個高技術依賴性的行業&#xff0c;有機會被淘汰嗎?我們今天就來說說&#xff0c;幾乎不可能被AI淘汰的職業---護理。一) AI在護理中扮演的角色i.) 臨床工作支持1. 健康監測自動化即…