# vue3 实现web网页不同分辨率适配

vue3 实现web网页不同分辨率适配

首先这个标题可能不是特别的合适,之前开发了一个网站,那个网站是类似于官网的效果,按照 19201080 100% 的分辨率进行开发的,但是在开发完成之后,发现有的电脑是 19201080125% 的大小展示的,这样的话,有些地方可能展示就会出一些问题。当然了可以用第三方的一些插件进行处理,也可以自己想办法处理一下,这篇博文就是靠自己处理,简单写一下思路。

内容

首先,最显而易见的操作就是开发的过程中尽可能用弹性盒子布局,组建页面的时候尽可能使用百分比布局。其次,在设置文本大小、间距这类的数据时候,需要使用 rem 进行设置,而不是 px

这里推荐一个 vscode 编辑器好用的 rem 转换工具,叫 "px to rem & rpx & vw (cssrem)"。

这个插件还是可以的!

然后呢,做完了这些的话,就简单了,我们在加载完页面的时候,先判断一下,这个浏览器的宽度是不是 1920 的,因为我们是按照宽度是 1920 的分辨率开发适配的,如果不是的话,我们需要根据当前的宽度,结合我们设计的比例,重新算一下,当前需要给html设置的 font-size 大小是多少(默认是16px)。然后就可以啦!'

typescript 复制代码
// APP.vue
onMounted(() => {
  let docEl = document.documentElement;
  let clientWidth = docEl.clientWidth;
  docEl.style.fontSize = 16 * (clientWidth / 1920) + 'px';
});

这样在我们打开页面的时候他会计算当前页面宽度与设计图宽度1920的比例,然后重新设置html标签的font-size属性值

这样我们的页面就可以拉回到设计图的大小了。

问题

这样实现的话存在一些问题:

  1. 网页中的 px 单位需要改成 rem 单位,如果开发没考虑,后期修改任务量会很大;
  2. 对于一些第三方组件可能无法实现适配,因为三方插件中内部使用的单位为px
相关推荐
小此方3 分钟前
【别传:Web前端开发(一)】快速构筑项目外壳:HTML 核心标签复习指南
前端·html
小此方4 分钟前
【别传:Web前端开发(二)】重塑视觉视界:CSS核心机理与弹性排版全景草稿
前端·css
智码看视界5 分钟前
Vue生态体系:构建现代化前端应用的完整解决方案
前端·javascript·vue.js
qq_2518364575 分钟前
基于java Web 哈尔滨文化活动网站毕业论文
java·开发语言·前端
LaughingZhu9 分钟前
Product Hunt 每日热榜 | 2026-06-10
前端·人工智能·经验分享·chatgpt·html
打小就很皮...10 分钟前
基于 Python + LangChain + React 实现智能发票识别与验真系统实战
前端·react.js·langchain·ocr·发票识别
惢雨10 分钟前
ts中的特殊符号说明并举例,如 ?. 、?:、??等
前端·typescript
小此方10 分钟前
【别传:Web前端开发(三)】重塑动态视界:JS底层逻辑、数据类型流转与WebAPI交互全景草稿
前端·javascript·交互
粉末的沉淀10 分钟前
css:隐藏video标签的下载按钮
前端·css
仰望.11 分钟前
vue表格使用 vxe-table 展开行实现产品列表与明细列表
前端·javascript·vue.js·vxe-table