搜索
首页web前端Vue.jsVue指令实现大屏元素分辨率适配详解

本篇文章给大家带来了关于vue的相关知识,主要介绍了Vue指令实现大屏元素分辨率适配详解,包括了常见的适配方案以及css缩放方案等等,下面一起来看一下,希望对大家有帮助。

Vue指令实现大屏元素分辨率适配详解

【相关推荐:javascript视频教程vue.js教程

随着前端技术的不断发展、数据中心(中台)之类的概念的不断升级、物联网设备的更新和普及,越来越多的业主(项目)喜欢在系统中添加一个或者多个可视化大屏,用来集中的展现数据变化、位置变化等等,老板们也更喜欢称之为“态势”。

当然,作为程序员一般都不关心“老板们”的想法,只要完成项目即可。但是经常会有这样的问题:我有一个大屏的模板,但是用户的浏览器分辨率不够,或者有的有书签栏有的没有书签栏,更或者是有的全屏了有的只是小窗口,这样就有了代码对不同分辨率场景下的适配需求了。

1. 常见的适配方案

平时我们使用的 web 端的适配方案,主要有以下几种:

  • vw/vh 配合百分比实现,让元素根据窗口大小进行自动调整
  • fontSize 配合 rem 实现“单位宽度”的统一
  • 根据不同的分辨率范围调整页面布局
  • 版心布局,配合最小宽度

目前大多数屏幕适配方案的原理都是采用的以上的几种方式,但是这几种方式也有很大的弊端:浏览器文字有最小尺寸!

在一般的 1080p 及以上的分辨率的屏幕中,大多数设计图的比例和显示效果都能完美还原。但如果某个系统的页面内容太多,或者浏览器部分使用的分辨率(不是物理分辨率)达不到完整显示的要求,采用上面的几种方式就有可能造成 文字的计算大小小于浏览器的最小字体大小,此时就有可能因为文字宽度超出元素而导致页面样式崩溃。

版心布局配合最小宽度可以保证显示效果,但是不适合大屏项目。

2. CSS3 缩放方案

在上面的几种方案都不满足时,大家一般就会采用另外一种方案:CSS3 scale 缩放。

通过计算设计图尺寸比例与实际的页面显示区域大小,来动态调整元素的缩放比例。

个人认为这是针对小分辨率情况下保留显示内容及样式最好的一种处理方式。

当然,这种方式依然有一些弊端:

  • 缩放后可能会造成边缘显示模糊
  • 如果内部存在 canvas 元素,可能导致 canvas 内部的内容渲染失真
  • 高德地图 1.x 会导致事件坐标偏移 (2.0 已经修复)
  • ...

3. 封装一个缩放指令

这里简单回顾一下 Vue 的自定义指令:通过配置自定义指令和绑定参数,在组件/元素加载、更新、销毁等不同时期执行对应的处理逻辑。

Vue 的自定义指令包含一下几个钩子函数:

  • bind: 解析到指令绑定时执行,仅执行一次
  • inserted: 插入父节点时执行
  • update:组件触发更新时执行
  • componentUpdated:所有组件更新结束之后执行
  • unbind:元素解绑(销毁)时执行,也只执行一次

这里因为我们只需要在初始化时绑定浏览器的 resize 事件来调整元素缩放,所以只需要配置 inserted 即可;当然,为了优化代码逻辑,减少资源消耗等情况,也需要在 unbind 阶段去取消 resize 事件的一个回调函数。

代码如下:

// 缩放指令
import Vue from "vue";
function transformScale(el, options) {
  const { target = "width", origin = "top left" } = options;
  Vue.nextTick(() => {
    // 获取显示区域高宽
    const width = window.innerWidth;
    const height = window.innerHeight;
    el.style.transformOrigin = origin;
    if (target === "ratio") {
      const scaleX = width / CONF.width;
      const scaleY = height / CONF.height;
      el.style.transform = `scaleX(${scaleX}) scaleY(${scaleY})`;
    } else {
      let scaleProportion = 1;
      if (target === "width") {
        scaleProportion = width / CONF.width;
      }
      if (target === "height") {
        scaleProportion = height / CONF.height;
      }
      el.style.transform = `scale(${scaleProportion})`;
    }
  });
}
function inserted(el, binding) {
  const options = binding.options || { passive: true };
  const callback = () => transformScale(el, binding.value);
  window.addEventListener("resize", callback);
  callback();
  el._onResize = {
    callback,
    options
  };
}
function unbind(el) {
  if (!el._onResize) {
    return;
  }
  const { callback } = el._onResize;
  window.removeEventListener("resize", callback);
  delete el._onResize;
}
export const Scale = {
  inserted,
  unbind
};
export default Scale;

说明:

  • 指令接收一个对象参数,用来指定比例计算方式和缩放定位
  • 需要一个全局配置 CONF 对象,用来指定默认的页面尺寸
  • 为了保证页面已经加载完,能获取到 dom 元素,需要调用 Vue.nextTick
  • 需要销毁监听事件

整个代码其实很简单,就是通过监听 resize 事件去调整元素的缩放比例。

但是这里我也做了一点小的配置,用来适应更多的情况:

  • 接收一个 target 配置,用来确认比例计算方式;可以以宽度或者高度作为统一的缩放标准,也可以分别计算
  • 接收 transform 的 origin 配置,保证不同位置的元素可以缩放到不同的位置,避免缩放偏移
  • 不涉及绑定元素的尺寸,只需要默认尺寸即可;写代码时可以直接根据设计图配置元素尺寸

当然,这个指令不能说有多完美,依然有很多有漏洞的地方,比如没有防抖、缩放不会改变css指定的尺寸,容易出现滚动条等;

并且因为之前的项目中还涉及到很多图表、地图,也经常导致一些显示问题,所以后面有增加了一些新的指令,但是分辨率适配这个问题还是要根据实际情况来确定具体的方案。

【相关推荐:javascript视频教程vue.js教程

以上是Vue指令实现大屏元素分辨率适配详解的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:脚本之家。如有侵权,请联系admin@php.cn删除
vue.js的功能:增强前端的用户体验vue.js的功能:增强前端的用户体验Apr 19, 2025 am 12:13 AM

Vue.js通过多种功能提升用户体验:1.响应式系统实现数据即时反馈;2.组件化开发提高代码复用性;3.VueRouter提供平滑导航;4.动态数据绑定和过渡动画增强交互效果;5.错误处理机制确保用户反馈;6.性能优化和最佳实践提升应用性能。

vue.js:定义其在网络开发中的作用vue.js:定义其在网络开发中的作用Apr 18, 2025 am 12:07 AM

Vue.js在Web开发中的角色是作为一个渐进式JavaScript框架,简化开发过程并提高效率。1)它通过响应式数据绑定和组件化开发,使开发者能专注于业务逻辑。2)Vue.js的工作原理依赖于响应式系统和虚拟DOM,优化性能。3)实际项目中,使用Vuex管理全局状态和优化数据响应性是常见实践。

了解vue.js:主要是前端框架了解vue.js:主要是前端框架Apr 17, 2025 am 12:20 AM

Vue.js是由尤雨溪在2014年发布的渐进式JavaScript框架,用于构建用户界面。它的核心优势包括:1.响应式数据绑定,数据变化自动更新视图;2.组件化开发,UI可拆分为独立、可复用的组件。

Netflix的前端:React(或VUE)的示例和应用Netflix的前端:React(或VUE)的示例和应用Apr 16, 2025 am 12:08 AM

Netflix使用React作为其前端框架。1)React的组件化开发模式和强大生态系统是Netflix选择它的主要原因。2)通过组件化,Netflix将复杂界面拆分成可管理的小块,如视频播放器、推荐列表和用户评论。3)React的虚拟DOM和组件生命周期优化了渲染效率和用户交互管理。

前端景观:Netflix如何处理其选择前端景观:Netflix如何处理其选择Apr 15, 2025 am 12:13 AM

Netflix在前端技术上的选择主要集中在性能优化、可扩展性和用户体验三个方面。1.性能优化:Netflix选择React作为主要框架,并开发了SpeedCurve和Boomerang等工具来监控和优化用户体验。2.可扩展性:他们采用微前端架构,将应用拆分为独立模块,提高开发效率和系统扩展性。3.用户体验:Netflix使用Material-UI组件库,通过A/B测试和用户反馈不断优化界面,确保一致性和美观性。

React与Vue:Netflix使用哪个框架?React与Vue:Netflix使用哪个框架?Apr 14, 2025 am 12:19 AM

NetflixusesAcustomFrameworkcalled“ Gibbon” BuiltonReact,notReactorVueDirectly.1)TeamExperience:selectBasedAsedonFamiliarity.2)ProjectComplexity:vueforsimplerprojects,vueforsimplerprojects,reactforforforecomplexones.3)cocatizationNeedsneeds:reactofficatizationneedneeds:reactofferizationneedneedneedneeds:reactoffersizatization needeffersefersmoreflexiblesimore.4)ecosyaka

框架的选择:是什么推动了Netflix的决定?框架的选择:是什么推动了Netflix的决定?Apr 13, 2025 am 12:05 AM

Netflix在框架选择上主要考虑性能、可扩展性、开发效率、生态系统、技术债务和维护成本。1.性能与可扩展性:选择Java和SpringBoot以高效处理海量数据和高并发请求。2.开发效率与生态系统:使用React提升前端开发效率,利用其丰富的生态系统。3.技术债务与维护成本:选择Node.js构建微服务,降低维护成本和技术债务。

反应,vue和Netflix前端的未来反应,vue和Netflix前端的未来Apr 12, 2025 am 12:12 AM

Netflix主要使用React作为前端框架,辅以Vue用于特定功能。1)React的组件化和虚拟DOM提升了Netflix应用的性能和开发效率。2)Vue在Netflix的内部工具和小型项目中应用,其灵活性和易用性是关键。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。