我的编程空间,编程开发者的网络收藏夹
学习永远不晚

uniapp+Html5端怎么实现PC端适配

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

uniapp+Html5端怎么实现PC端适配

这篇文章给大家分享的是有关uniapp+Html5端怎么实现PC端适配的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

前言:

使用uniapp做的h6页面,在PC端显示时,发现由于upx单位计算基准值太大,导致页面排班布局错乱

思路:

刚开始发现使用px单位不会导致页面布局混乱,但这对刚开启的项目友好,对已经成型的项目修改成本太高,风险也大,而且px是固定单位,在移动端显然没upx好使;

后来百度好久,发现都没有解决办法,偶然间突发奇想,能不能利用iframe在页面载入前将宽度设置为375px(750upx),来达到欺骗浏览器,欺骗uniapp,让浏览器以375px(这个值可以自己按需设置)基准值来计算upx=>px转换比,然后setimeout 300毫秒(延迟时间自己试验吧,不一定300ms效果最好)将iframe宽度设置为100%,这样一来在PC端就可以实现以375upx基准值渲染页面了;

说干就干,demo在下面

pages.json: (iframe为项目首页,用来判断是移动端还是PC端,并对PC端做适配处理)

{ "pages": [  {   "path": "pages/iframe"  },  {   "path": "pages/index/index"  } ], "globalStyle": {  "navigationStyle" : "custom",  "navigationBarTextStyle": "black",  "navigationBarTitleText": "DEMO",  "navigationBarBackgroundColor": "#F8F8F8",  "backgroundColor": "#F8F8F8" }}

pages/iframe页面

<style lang="scss"> .container{  height: 100%;  iframe{   display: block;   width: 375px;   height: 100%;   opacity: 0;   animation: fadeShow .3s ease-in forwards .3s;  } } @keyframes fadeShow {  0% {   opacity: 0;  }  100%{   opacity: 1;  } }</style>
<template> <view class="container flex justify-center">  <iframe v-if="!ismobile" :class="lazy" data-src="url" frameborder="0" :style="'width:'+width"></iframe> </view></template>
<script> export default {  data() {   return {    url: '',    width: '',    ismobile: true,   };  },  onLoad(opt) {   this.ismobile = this.isMobile();   let url = 'pages/index/index';//你的首页   if(this.ismobile){    uni.redirectTo({     url: `/${url}`    })   }else{    this.url = `${location.href}${url}`;    this.width = '375px';    setTimeout(() => {     this.width = '100%';    },300)   }  },  onShow() {     },  methods:{   isMobile() {          let flag = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)          return flag?true:false;         }  } };</script>

缺陷:

f5刷新页面时又会回到iframe初始页面

2019/11/25更新:

好吧,今天去官方社区逛了一圈,发现有大神已经提出PC端适配方案了,就几句代码就OK了,突然发现我真是蠢啊,┭┮﹏┭┮

基于大神的方案修改了下:

新建一个pc.js,随便找个地方放着,内部代码如下(变量sw值的设置,你们觉得怎么好看怎么来吧,下面的是我根据我的感觉设置的,适配到8K屏幕了):

;(function (){ var u = navigator.userAgent,  w = window.innerWidth; if (!u.match(/AppleWebKit.*Mobile.*/) || u.indexOf('iPad') > -1) {  var sw = w*576/1920;  window.innerWidth = sw<375?375:sw;                window.onload = function() {          window.innerWidth = w;         } }})();

然后再main.js里面引入pc.js

注意,pc.js一定要在App实例引入前引入,不然无效!!!

import '@/static/js/pc'import Vue from 'vue'import App from './App'

这样做的好处是刷新页面时,页面之前的栈还在,不会像用iframe那样刷新后就回到首页;

至于我上面方案直接无视吧!┗( ▔, ▔ )┛

2019/11/26更新:

pc.js修改成下面这样, PC端样式就可以实现1upx = 1rpx = 1px;这样非常方便的1:1还原设计图了

当然如果你的设计图不是1920,比如是1366,那下面就改成这样window.innerWidth = 750*(w / 1366);

;(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;  } }})();

感谢各位的阅读!关于“uniapp+Html5端怎么实现PC端适配”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

uniapp+Html5端怎么实现PC端适配

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

uniapp+Html5端怎么实现PC端适配

这篇文章给大家分享的是有关uniapp+Html5端怎么实现PC端适配的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言:使用uniapp做的h6页面,在PC端显示时,发现由于upx单位计算基准值太大,导致页面排
2023-06-09

html5如何实现移动端适配

这篇文章将为大家详细讲解有关html5如何实现移动端适配,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在pc版网页(http://pc_url) 上,添加:
2023-06-09

html5中如何使用hotcss.js实现手机端自适配

这篇文章将为大家详细讲解有关html5中如何使用hotcss.js实现手机端自适配,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简介使用动态的HTML根字体大小和动态的viewport scale。遵循视
2023-06-09

使用html5怎么实现移动端自适应布局

这篇文章给大家介绍使用html5怎么实现移动端自适应布局,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1.使用媒体查询,下面制定了几种适应方式,例如第一个表示屏幕宽度在320px-360px之间的,html字体大小适配
2023-06-09

vue-draggable怎么实现pc端拖拽效果

本文小编为大家详细介绍“vue-draggable怎么实现pc端拖拽效果”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue-draggable怎么实现pc端拖拽效果”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧
2023-06-29

Vue PC端怎么实现扫码登录功能

本文小编为大家详细介绍“Vue PC端怎么实现扫码登录功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue PC端怎么实现扫码登录功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。.markdown-bod
2023-07-05

vue2+tracking怎么实现PC端的人脸识别

本篇内容介绍了“vue2+tracking怎么实现PC端的人脸识别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!需求上传患者真实头像,可以有
2023-06-30

怎么在html5中实现分层屏幕适配

本篇文章为大家展示了怎么在html5中实现分层屏幕适配,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。屏幕适配屏幕适配应当指内容 适配区 和 屏幕区 间的适配关系。单屏适配有 contain、cove
2023-06-09

使用HTML5怎么实现移动端开发

这篇文章将为大家详细讲解有关使用HTML5怎么实现移动端开发,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1. 弹出数字键盘
2023-06-09

使用postcss-pxtorem怎么适配移动端

今天就跟大家聊聊有关使用postcss-pxtorem怎么适配移动端,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。执行命令 安装插件postcss-pxtoremnpm instal
2023-06-08

HTML5怎么在手机端实现视频全屏

本篇内容主要讲解“HTML5怎么在手机端实现视频全屏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“HTML5怎么在手机端实现视频全屏”吧!最近做项目,遇到一个问题,在手机上要实现视频的全屏播放功
2023-06-09

怎么在HTML5中实现移动端复制功能

本篇文章为大家展示了怎么在HTML5中实现移动端复制功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。使用clipboard.js实现移动端粘贴复制 clipboard.js是一款很强大的粘贴复制的
2023-06-09

Vue前端项目自适应布局怎么实现

这篇文章主要介绍“Vue前端项目自适应布局怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue前端项目自适应布局怎么实现”文章能帮助大家解决问题。一、单位尺寸px%vw、vh: 窗口em:
2023-07-02

使用HTML5怎么实现移动端简易进度条

使用HTML5怎么实现移动端简易进度条?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。touchstart: 当手指触摸屏幕时候触发,即使已经有一个手指放在屏幕上
2023-06-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录