| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> 大屏适配解决方案 VUE -> 正文阅读 |
|
[JavaScript知识库]大屏适配解决方案 VUE |
最近在做一个数据可视化的项目,整个项目全是大屏展示,期间也是遇到很多问题,最令人头疼的就是大屏的适配。我这个项目是要投放到4K超大屏上展示,自然要考虑到分辨率,浏览器缩放,字体(包括图表中的字体)的适配。下面介绍一下适配方案(或许并不是最好的,目前用着还是可以解决,本人菜鸟一个,大佬有更好更优雅的方式评论区请指教): 1.flex布局布局肯定是选择css3中的flex布局了,尽量多使用百分比,避免使用px单位的使用,相信作为前端工程师(高大上哈哈)的我们在布局这块儿应该都没啥问题,这里就不多说~~~~ 2.字体(不包括echart图表这种)不说废话,直接上了 在@/utils文件夹下建flexible.js文件 flexible.js文件:
然后需要的页面中引入该文件即可:import '@/utils/flexible'(其实就是立即调用了上面的方法) 引入之后注意:?上面 正常情况下是1rem == 16px 这里需要修改一下,我们使用vsCode开发,下载 点击设置->扩展设置将? 修改为192,因为上面是根据浏览器的宽度来计算的,十分之一宽度为1rem,正常浏览器分辨率为1920*1080,所以这里修改为192 这样就ok啦!所有单位都不要使用px,转为rem即可。(好像屏幕缩放超过150%就不起作用了,字体会变大,不过不重要,投放到大屏上面其实是缩小的,符合)? 3.echart图表中的字体适配在@/utils文件夹下建echartPxToRem.js文件 echartPxToRem.js文件
?在echarts文件中 import { fontChart } from '@/utils/echartPxToRem'引入 然后在设置字体大小的地方去调用fontChart这个方法(echar中默认字体单位都是px)例如: 这样设置好之后保存 ---? 你会发现不起作用? 还需要关键的一步!!如下: 我们要监听浏览器的变化,浏览器改变的时候重新调用加载echarts图表的方法,其实就是重新调一下fontChart这个方法,重新根据浏览器计算一下以达到字体适配? ?这里注意几个细节: 一:监听使用window.addEventListener而不使用window.onresize是因为一个页面存在了很多个图表,如果使用window.onresize方法,你会发现只有最后一个起作用,前面的都失效了,这是因为onresize本身就是一个回调,当你改变的时候,前一个就会被覆盖。 二:这里window.addEventListener,第二个参数传的不是匿名函数,什么意思呢?如下: 上面这个就是一个匿名函数,这种方式同样可以达到重新调用fontChart方法,实现echart字体适配,但是为什么不使用这种?因为window.addEventListener第二个参数传的是匿名函数将无法通过window.removeEventListener移除监听。 我们使用window.addEventListener监听事件,那么在离开页面的时候就要移除监听 ?如果不将该监听事件移除掉,那么这个监听事件会一直存在,即使在其他页面。 每个echart都需要监听window改变来适配,你想想一个数据可视化项目会有多少echart图表? 那么结果就是你的大屏页面会变得非常卡顿,亲测真的卡~~~~~ 好了 ,上面就是根据最近可视化项目的一些经验总结的一些适配方案,有大佬有更好的方式还请多多指教(抱拳) |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/6 13:47:54- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |