欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

前端vue按1920*1080設計圖的頁面適配屏幕縮放并適配4K屏詳解

 更新時間:2022年11月16日 11:43:11   作者:@#  
最近在做一個數據可視化的項目,整個項目全是大屏展示,期間也是遇到很多問題,最令人頭疼的就是大屏的適配,下面這篇文章主要給大家介紹了前端vue按1920*1080設計圖的頁面適配屏幕縮放并適配4K屏的相關資料,需要的朋友可以參考下

說明

公司項目做之前沒有溝通好,按照1920*1080設計圖做的頁面,縮放比是100%,項目做完之后說要適配縮放比,并且 適配4k屏,然后就各種百度找辦法。

一、首先是適配屏幕的縮放比

這種方法也是通過看別人發(fā)布的文章解決的,原來的地址在這:前端 解決筆記本屏幕顯示縮放比例125% 150%對頁面布局的影響

我是用的第二種方法,直接就粘過來了。

1.在外部創(chuàng)建一個detectZoom.js文件,我是在utils文件夾下

detectZoom.js文件代碼如下:

export const detectZoom = () => {
  let ratio = 0,
    screen = window.screen,
    ua = navigator.userAgent.toLowerCase();
  if (window.devicePixelRatio !== undefined) {
    ratio = window.devicePixelRatio;
  } else if (~ua.indexOf('msie')) {
    if (screen.deviceXDPI && screen.logicalXDPI) {
      ratio = screen.deviceXDPI / screen.logicalXDPI;
    }
  } else if (
    window.outerWidth !== undefined &&
    window.innerWidth !== undefined
  ) {
    ratio = window.outerWidth / window.innerWidth;
  }
  if (ratio) {
    ratio = Math.round(ratio * 100);
  }
  return ratio;
};

2.在main.js中引用

m是獲取的當前屏幕的縮放比,在通過zoom屬性對應縮放。

zoom屬性用于設置或檢索對象的縮放比例。

import { detectZoom } from '@/utils/detectZoom.js';
const m = detectZoom();
document.body.style.zoom = 100 / Number(m);

以上為解決屏幕縮放比的方法,在屏幕分辨率為1920*1080時可以解決。

二、解決4k屏幕的問題

在項目做完之后突然告知需要適配4k屏,并且4k屏的時候也會有屏幕縮放比,不想重新改頁面樣式就想了這個辦法。也是通過zoom屬性,原理就是通過整個body的縮放使系統(tǒng)的展示區(qū)域變成1920*1080

1.獲取當前屏幕的分辨率

獲取屏幕的寬:window.screen.width * window.devicePixelRatio

獲取屏幕的高:window.screen.height * window.devicePixelRatio

2.根據不同屏幕和縮放比來調節(jié)zoom的比例

在main.js中 代碼如下:

import { detectZoom } from '@/utils/detectZoom.js';

const m = detectZoom();
 //判斷屏幕是否為4k
if (window.screen.width * window.devicePixelRatio >=3840) {
  // switch (m) {
  //   // 4k屏時屏幕縮放比為100%
  //   case 100:
  //     document.body.style.zoom = 100 / 50;
  //     break;
  //     // 4k屏時屏幕縮放比為125%
  //   case 125:
  //     document.body.style.zoom = 100 / 62.5;
  //     break;
  //     // 4k屏時屏幕縮放比為150%
  //   case 150:
  //     document.body.style.zoom = 100 / 75;
  //     break;
  //     // 4k屏時屏幕縮放比為175%
  //   case 175:
  //     document.body.style.zoom = 100 / 87.4715;
  //     break;
  //     // 4k屏時屏幕縮放比為200%
  //   case 200:
  //     document.body.style.zoom = 100 / 100;
  //     break;
  //     // 4k屏時屏幕縮放比為225%
  //   case 225:
  //     document.body.style.zoom = 100 / 112.485;
  //     break;
  
  //   default:
  //     break;
  // }
  document.body.style.zoom = 100 / (Number(m)/2);
}else{
  document.body.style.zoom = 100 / Number(m);
}

最后結果:雖然屏是4k的,但是系統(tǒng)展示頁面的可視區(qū)域依舊是1920*1080的,頁面樣式也沒有亂。

總結

到此這篇關于前端vue按1920*1080設計圖的頁面適配屏幕縮放并適配4K屏的文章就介紹到這了,更多相關vue頁面適配屏幕縮放內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 對vue事件的延遲執(zhí)行實例講解

    對vue事件的延遲執(zhí)行實例講解

    今天小編就為大家分享一篇對vue事件的延遲執(zhí)行實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue?webpack的基本使用示例教程

    Vue?webpack的基本使用示例教程

    這篇文章主要介紹了Vue?webpack的基本使用,本文結合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • uniapp-ios開發(fā)之App端與webview端相互通信的方法以及注意事項

    uniapp-ios開發(fā)之App端與webview端相互通信的方法以及注意事項

    在uni-app與Webview之間進行數據交互是非常常見的需求,下面這篇文章主要給大家介紹了關于uniapp-ios開發(fā)之App端與webview端相互通信的方法以及注意事項的相關資料,需要的朋友可以參考下
    2024-07-07
  • 關于應用UI組件的移動端適配方式

    關于應用UI組件的移動端適配方式

    這篇文章主要介紹了關于應用UI組件的移動端適配方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue3中reactive數據被重新賦值后無法雙向綁定的解決

    vue3中reactive數據被重新賦值后無法雙向綁定的解決

    這篇文章主要介紹了vue3中reactive數據被重新賦值后無法雙向綁定的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue微信公眾號網頁分享的示例代碼

    Vue微信公眾號網頁分享的示例代碼

    這篇文章主要介紹了Vue微信公眾號網頁分享的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • Vuex持久化插件(vuex-persistedstate)解決刷新數據消失的問題

    Vuex持久化插件(vuex-persistedstate)解決刷新數據消失的問題

    這篇文章主要介紹了Vuex持久化插件(vuex-persistedstate)-解決刷新數據消失的問題,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04
  • 一文帶你搞定svg-icon的使用方式

    一文帶你搞定svg-icon的使用方式

    這篇文章主要介紹了一文帶你搞定svg-icon的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue組件間的雙向綁定示例解析

    Vue組件間的雙向綁定示例解析

    這篇文章主要介紹了Vue組件間的雙向綁定,我們都知道當父組件改變了某個值后,如果這個值傳給了子組件,那么子組件也會自動跟著改變,但是這是單向的,使用v-bind的方式,即子組件可以使用父組件的值,但是不能改變這個值
    2023-03-03
  • webpack vue 項目打包生成的文件,資源文件報404問題的修復方法(總結篇)

    webpack vue 項目打包生成的文件,資源文件報404問題的修復方法(總結篇)

    這篇文章主要介紹了解決webpack vue 項目打包生成的文件,資源文件報404問題的修復方法,需要的朋友可以參考下
    2018-01-01

最新評論