前端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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
uniapp-ios開發(fā)之App端與webview端相互通信的方法以及注意事項
在uni-app與Webview之間進行數據交互是非常常見的需求,下面這篇文章主要給大家介紹了關于uniapp-ios開發(fā)之App端與webview端相互通信的方法以及注意事項的相關資料,需要的朋友可以參考下2024-07-07vue3中reactive數據被重新賦值后無法雙向綁定的解決
這篇文章主要介紹了vue3中reactive數據被重新賦值后無法雙向綁定的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05Vuex持久化插件(vuex-persistedstate)解決刷新數據消失的問題
這篇文章主要介紹了Vuex持久化插件(vuex-persistedstate)-解決刷新數據消失的問題,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04webpack vue 項目打包生成的文件,資源文件報404問題的修復方法(總結篇)
這篇文章主要介紹了解決webpack vue 項目打包生成的文件,資源文件報404問題的修復方法,需要的朋友可以參考下2018-01-01