[web教学] 前端大屏适配几种方案

[复制链接]
查看580 | 回复0 | 2023-8-22 15:04:00 | 显示全部楼层 |阅读模式 来自 中国北京
       纪录一下前端大屏的几种适配方案。
我们是1920*1080的计划稿。

  

       大屏是适配是前端开发必不可少的技能,适配各种大屏也是为了给用户更好的体验。

一、方案一:rem+font-size

       动态设置HTML根字体巨细和body字体巨细,会使用到lib-flexible.js插件
lib-flexible.js
  1. (function flexible(window, document) {
  2.   var docEl = document.documentElement
  3.   var dpr = window.devicePixelRatio || 1
  4.   // adjust body font size
  5.   function setBodyFontSize() {
  6.     if (document.body) {
  7.       document.body.style.fontSize = (16 * dpr) + 'px'
  8.     }
  9.     else {
  10.       document.addEventListener('DOMContentLoaded', setBodyFontSize)
  11.     }
  12.   }
  13.   setBodyFontSize();
  14.   function setRemUnit() {
  15.     var rem = docEl.clientWidth / 24
  16.     docEl.style.fontSize = rem + 'px'
  17.   }
  18.   setRemUnit()
  19.   // reset rem unit on page resize
  20.   window.addEventListener('resize', setRemUnit)
  21.   window.addEventListener('pageshow', function (e) {
  22.     if (e.persisted) {
  23.       setRemUnit()
  24.     }
  25.   })
  26.   // detect 0.5px supports
  27.   if (dpr >= 2) {
  28.     var fakeBody = document.createElement('body')
  29.     var testElement = document.createElement('div')
  30.     testElement.style.border = '.5px solid transparent'
  31.     fakeBody.appendChild(testElement)
  32.     docEl.appendChild(fakeBody)
  33.     if (testElement.offsetHeight === 1) {
  34.       docEl.classList.add('hairlines')
  35.     }
  36.     docEl.removeChild(fakeBody)
  37.   }
  38. }(window, document))
复制代码
我们可以将它下载下来。打开js文件,将计划稿的宽度(1920px)均匀分成24等份,每一份为80px。将这个值设置为html字体巨细,既1rem = 80px; 24rem = 1920px。

tips:rem是根据html字体巨细来盘算的,如果html字体为16px,则1rem就等于16px;

       在移动端通常会分成10份,PC端分成24份。
       安装cssrem插件,根节点的字体巨细设置为80px。这个是px单元转rem的参考值。

配置插件的基准值:

如许的话放我们在誊写px的得当,这个插件就会主动帮我们转化成rem。
  1. <!DOCTYPE html>
  2. <html lang="en">
  3.   <head>
  4.     <meta charset="UTF-8" />
  5.     <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6.     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7.     <title>Document</title>
  8.    
  9.   </head>
  10.   <body>
  11.     <ul>
  12.       <li>1</li>
  13.       <li>2</li>
  14.       <li>3</li>
  15.       <li>4</li>
  16.       <li>5</li>
  17.       <li>6</li>
  18.     </ul>
  19.   </body>
  20.   [script][/script]
  21. </html>
复制代码
1.检察适配情况

1.1 1920*1080情况下


1.2 3840*2160(4k屏)情况下

3840也是分成24等份:3840 / 24 = 160

1.3 7680*2160 超宽屏下

超宽屏情况下只显示了上半部分,这种适配方式比力得当16:9的情况下使用,后面会有其他方案办理这个问题。

二、方案二:vw(单元)

      直接使用vw单元,屏幕宽度默认为100vw,那么100vw = 1920px;1vw = 19.2px。这个也是使用cssrem插件,直接将body的宽高(1920px * 1080px),将px转成vw单元。

这种方案和第一个方案雷同,超宽屏的情况下也是不能全部显示。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.   <head>
  4.     <meta charset="UTF-8" />
  5.     <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6.     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7.     <title>Document</title>
  8.    
  9.   </head>
  10.   <body>
  11.     <ul>
  12.       <li>1</li>
  13.       <li>2</li>
  14.       <li>3</li>
  15.       <li>4</li>
  16.       <li>5</li>
  17.       <li>6</li>
  18.     </ul>
  19.   </body>
  20. </html>
复制代码
三、方案三:scale(缩放)猛烈保举

      很多的大屏适配都是使用的这种方案。
这种方案的原理就是根据宽高比例进行缩放。
1、根据宽度比率进行缩放

(宽度比率=网页当前宽度/计划稿宽度)
  1. [script]
  2.     // 设计稿:1920 * 1080
  3.     // 1.设计稿尺寸
  4.     let targetWidth = 1920;
  5.     // 2.拿到当前设备(浏览器)的宽度
  6.     // document.documentElement  获取html的宽度
  7.     let currentWidth =
  8.       document.documentElement.clientWidth || document.body.clientWidth;
  9.     // 3.计算缩放比率(屏幕过宽,根据高度计算缩放比例)
  10.     let scaleRatio = currentWidth / targetWidth;
  11.     // 4.开始缩放网页
  12.     document.body.style = `transform: scale(${scaleRatio})`;
  13.   [/script]
复制代码
      上面这种根据宽度比例进行缩放的,针对1920 * 1080,3840 * 2160(4k)是没有问题的,但是在超宽屏的情况下还是存在只显示一半的问题。
分析缘故原由:
  1. 我们的设计稿:
  2. 1920 * 1080 => 要适配 (1920*2=3840, 1080*2=2160, 4k屏) 3840 * 2160
  3. 也要适配=> ( 1920*4 = 7680 : 1080 * 2 = 2160) 7680 * 2160
  4. 我们当前是根据宽度比率进行缩放的:
  5. 先设配3840 * 2160
  6. scaleRatio = 3840 / 1920  = 2
  7. 根据这个缩放比率
  8. 我们的设计稿宽高都会被缩放两倍
  9. 1920 * 2 = 3840
  10. 1080 * 2 = 2160
  11. 设配7680 * 2160
  12. scaleRatio = 7680 / 1920  =  4
  13. 根据这个宽度比例我们的设置稿宽高都会被缩放4倍
  14. 1920 * 4 = 7680
  15. 1080 * 4  = 4240
  16. 这个原先的比例是 4 : 2,现在变成了 4 :4 ,这也是为什么我们只看到一半高度的原因。
复制代码
2、动态盘算

      动态盘算网页宽高比,决定是按照宽度的比例还是高度的比例进行缩放。
  1.   [script]
  2.     // 设计稿:1920 * 1080
  3.     // 1.设计稿尺寸
  4.     let targetWidth = 1920;
  5.     let targetHeight = 1080;
  6.     let targetRatio = 16 / 9; // 宽高比率 (宽 / 高)
  7.     // 2.拿到当前设备(浏览器)的宽度和高度
  8.     let currentWidth =
  9.       document.documentElement.clientWidth || document.body.clientWidth;
  10.     let currentHeight =
  11.       document.documentElement.clientHeight || document.body.clientHeight;
  12.     // 3.计算缩放比率(屏幕过宽,根据高度计算缩放比例)
  13.                 // 若currentWidth是4k屏宽度 3840 除于 我们设计稿的宽度 1920  3840/1920 = 2
  14.                 // 这样页面就行进行2倍缩放
  15.     let scaleRatio = currentWidth / targetWidth; // 参照宽度进行缩放(默认情况下)
  16.                
  17.     // 当前页面宽高比例,当页面越宽currentRatio值就越大
  18.     let currentRatio = currentWidth / currentHeight;
  19.                
  20.                 // 判断是根据宽度进行缩放,还是根据高度进行缩放
  21.     if (currentRatio > targetRatio) {
  22.       // 根据高度进行网页的缩放
  23.       scaleRatio = currentHeight / targetHeight; // 参照高度进行缩放(屏幕很宽的情况下)
  24.       document.body.style = `transform: scale(${scaleRatio}) translateX(-50%)`;
  25.     } else {
  26.       // 根据宽度进行网页的缩放
  27.       document.body.style = `transform: scale(${scaleRatio})`;
  28.     }
  29.   [/script]
复制代码
2.1、超宽屏终极适配结果



完备demo代码:
  1. <!DOCTYPE html>
  2. <html lang="en">
  3.   <head>
  4.     <meta charset="UTF-8" />
  5.     <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6.     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7.     <title>Document</title>
  8.    
  9.   </head>
  10.   <body>
  11.     <ul>
  12.       <li>1</li>
  13.       <li>2</li>
  14.       <li>3</li>
  15.       <li>4</li>
  16.       <li>5</li>
  17.       <li>6</li>
  18.     </ul>
  19.   </body>
  20. </html>
  21.   [script]    // 计划稿:1920 * 1080    // 设配目标:1920 * 1080 ( 1 : 1) | 3840* 2160 ( 2 : 2 ) | 7680 * 2160 ( 4 : 2)    // 1.计划稿尺寸    let targetWidth = 1920;    let targetHeight = 1080;    let targetRatio = 16 / 9; // 宽高比率 (宽 / 高)    // 2.拿到当前装备(欣赏器)的宽度    let currentWidth =      document.documentElement.clientWidth || document.body.clientWidth;    let currentHeight =      document.documentElement.clientHeight || document.body.clientHeight;    // 3.盘算缩放比率(屏幕过宽,根据高度盘算缩放比例)    let scaleRatio = currentWidth / targetWidth; // 参照宽度进行缩放(默认情况下)    // 当前宽高比例    let currentRatio = currentWidth / currentHeight;    if (currentRatio > targetRatio) {      scaleRatio = currentHeight / targetHeight; // 参照高度进行缩放(屏幕很宽的情况下)      document.body.style = `transform: scale(${scaleRatio}) translateX(-50%); left: 50%;`;    } else {      // 4.开始缩放网页      document.body.style = `transform: scale(${scaleRatio})`;    }  [/script]
复制代码
      近来看网上不停在说前端,Java的行情不好,不敷也确实云云,我好几个朋友都在找工作,也是说现在工作挺难找的,不知道讲何区何从,怕是会转行吧。唉,工作是为了生活,其时在当下的社会里,很多人包罗我本身,都被工作给填满了,没有空余的时间发展本身的爱好了,挺难过的,我这种从农村出来的人,刚出社会也是信心满满,想要干出一番奇迹,何曾想被每天的工作堆满,大概很多人从出生就注定了只能当螺丝钉啊,但是我渴望我这个螺丝钉是在最重要的部分,哈哈,见笑了,吐槽一下就行了。生活还要继续,来日诰日会更好,加油吧,同志。

来源:https://blog.csdn.net/Liushiliu104/article/details/129372083
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则