vite框架下大屏适配方案的几种实现方法

 更新时间:2025年10月30日 11:35:10   作者:李剑一  
本文主要介绍了vite框架下大屏适配方案小结,包括相对单位适配、媒体查询适配和缩放适配,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前情

最近打算写几个大屏,作为后续工作的一个简历吧。毕竟现在技术类的找工作不单单的是得会忽悠,还得有点儿作品。

怎么好像在说UI岗一样,在网上扒了扒效果,想要写的炫酷一些,页面开发完了以后在公司给一哥们演示的时候拉跨了。

家里的电脑屏幕本身是2K的,而公司里的是普通的1080p的。

原本在家里适配的非常好的页面在公司非常别扭,而且大量的宽度、高度、字体因为是写死的,在1080p的屏幕上出现了换行。

唉,百密一疏啊!页面效果、动画展示、数据加载等等都考虑到了,就是没考虑屏幕兼容...

方案选择

紧急调研了一下,现在比较主流的兼容方案一般有以下几种:

  1. 相对单位适配:
  • 使用相对单位如vw、vh、vmin、vmax,这些单位会根据屏幕的宽度和高度进行适配,从而实现不同屏幕下的适配。
  • 但是问题在于这种情况下可能出现小屏幕拥挤、大屏幕空旷的问题。
  1. 媒体查询适配:
  • 通过媒体查询(@media)来实现不同屏幕下的适配。各种屏幕都考虑到了,并且针对性的进行优化,能够保证效果相对来说处于最佳。
  • 但是问题在于,如果要兼容的屏幕很多,那么代码就会很复杂,并且容易出错。
  1. 缩放适配
  • 通过使用transform: scale() 来实现不同屏幕下的适配。简单快捷,几乎不用额外的考虑极端情况。
  • 但是问题在于,缩放后的页面可能不太好看。尤其是特殊屏幕可能会出现大黑边的情况。

层层筛选还是打断用相对单位做,但是可以使用 less 函数来简化这个过程。

简单地说就是使用 less 函数让他在编译过程中自动的将 px 转化为 vw/vh,实现相对比较完美的显示效果。

代码开发

  1. 首先安装 less
npm i less --save-dev
  1. 创建一个util.less作为工具函数
@charset "utf-8";

// 默认设计稿的宽度
@designWidth: 1920;

// 默认设计稿的高度
@designHeight: 1080;

// px 转 vw
.px2vw(@name, @px) {
  @{name}: (@px / @designWidth) * 100vw;
}

// px 转 vh
.px2vh(@name, @px) {
  @{name}: (@px / @designHeight) * 100vh;
}
  1. 在vite中使用 preprocessorOptions 为每个less插入工具函数
export default defineConfig({
    css: {
        preprocessorOptions: {
            less: {
                additionalData: `@import "@/assets/css/utils.less";`
            }
        }
    }
})
  1. vue 中使用
<style scope lang='less'>
    .card {
        .px2vw(width, 400);
        .px2vh(height, 300);
    }
</style>

总结

非常简单的一个小方案,但是却实现了相当不错的效果。适配上来说也还算比较的好吧,但是肯定是不如媒体查询那么完美。

不过从实现上来说比媒体查询的难度下降了不是一个量级。

最大的难度或许来自于你在 css 中写 .px2vw(width, 200) 这种别扭的感觉。

到此这篇关于vite框架下大屏适配方案小结的文章就介绍到这了,更多相关vite 大屏适配内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue 使用v-model实现控制子组件显隐效果

    Vue 使用v-model实现控制子组件显隐效果

    v-model 可以实现双向绑定的效果,允许父组件控制子组件的显示/隐藏,同时允许子组件自己控制自身的显示/隐藏,本文给大介绍Vue 使用v-model实现控制子组件显隐,感兴趣的朋友一起看看吧
    2023-11-11
  • Vue触发隐藏input file的方法实例详解

    Vue触发隐藏input file的方法实例详解

    这篇文章主要介绍了Vue触发隐藏input file的方法实例详解,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-08-08
  • vue.js在标签属性中插入变量参数的方法

    vue.js在标签属性中插入变量参数的方法

    这篇文章主要介绍了vue.js在标签属性中插入变量参数的方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-03-03
  • Vue动态组件加载失败:原因、排查与解决过程

    Vue动态组件加载失败:原因、排查与解决过程

    本文将探讨动态组件加载失败的常见原因,并提供排查与解决方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • vue.js动态数据绑定学习笔记

    vue.js动态数据绑定学习笔记

    这篇文章主要为大家详细介绍了vue.js动态数据绑定学习笔记,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • Vue3中使用pinia的示例代码

    Vue3中使用pinia的示例代码

    这篇文章主要介绍了Vue3中使用pinia,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-12-12
  • 浅析前端路由简介以及vue-router实现原理

    浅析前端路由简介以及vue-router实现原理

    路由就是用来跟后端服务器进行交互的一种方式,通过不同的路径,来请求不同的资源,请求不同的页面是路由的其中一种功能。这篇文章主要介绍了前端路由简介以及vue-router实现原理,需要的朋友可以参考下
    2018-06-06
  • rollup打包vue组件并发布到npm的方法

    rollup打包vue组件并发布到npm的方法

    这篇文章主要介绍了rollup打包vue组件并发布到npm,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • vue3如何添加eslint校验(eslint-plugin-vue)

    vue3如何添加eslint校验(eslint-plugin-vue)

    这篇文章主要介绍了vue3如何添加eslint校验(eslint-plugin-vue),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • vue中使用mixins/extends传入参数的方式

    vue中使用mixins/extends传入参数的方式

    这篇文章主要介绍了vue中使用mixins/extends传入参数的方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05

最新评论