uniapp h5端兼容pc端

大致效果就是用pc端打开h5网页,然后pc端可以像h5那样,不过pc端是页面居中左右两边留白的效果

第一步、创建一个js文件(随便创建在哪个位置)

// #ifdef H5
(function () {
  var u = navigator.userAgent,
    w = window.innerWidth;
  if (!u.match(/AppleWebKit.*Mobile.*/) || u.indexOf("iPad") > -1) {
    window.innerWidth = 750 * (w / 1920);
    window.onload = function () {
      window.innerWidth = w;
    };
  }
})();
// #endif

第二步、App.vue添加适配样式

<style lang="scss">
/*  #ifdef  H5  */
body {
  max-width: 828rpx;  //最大宽度自己可以调整
  margin: auto !important;
}
/*  #endif  */
</style>

第三步、main.js中引入pc.js(要在导入app示例之前引入

import Vue from "vue";
//导入PC适配JS(H5)
// #ifdef H5
import "./common/services/pc";
// #endif
import App from "./App";

注意:“可能在pc端刷新会页面撑大,建议直接把最大宽度(max-width直接给定死到你要的“px”单位而不是rpx单位,所有的rpx单位都得换成px单位,因为pc端不支持rpx单位)”

比如我这里写的是828prx,那直接写成414px单位,如果觉得还是有点宽的话,可以改小一点,按照自己的需求来

uni-app项目中,如果在代码中删除了import组件的导入,但忘记删除components里面的组件注册,就会导致启动编译时出现错误。这种错误会表现为一些具体的错误提示信息。另外,如果在模板中存在某些特定的语法,比如data.scrapYear||{},可能会导致报错。同时,如果后的接口数据返回null,则在微信小程序中会渲染成null,而在H5则不会。此外,uniapp不支持动态插槽,在项目中使用动态插槽可能会导致报错。所以,需要特别注意在uni-app项目中避免使用不支持的语法和特性,以确保编译无误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [uni-app编译时出现的错误](https://blog.csdn.net/weixin_45667658/article/details/120966198)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [uniapp编译成微信小程序中遇到的兼容性问题](https://blog.csdn.net/weixin_42424283/article/details/130682756)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值