前端vue按1920*1080設(shè)計(jì)圖的頁(yè)面適配屏幕縮放并適配4K屏詳解
說(shuō)明
公司項(xiàng)目做之前沒(méi)有溝通好,按照1920*1080設(shè)計(jì)圖做的頁(yè)面,縮放比是100%,項(xiàng)目做完之后說(shuō)要適配縮放比,并且 適配4k屏,然后就各種百度找辦法。
一、首先是適配屏幕的縮放比
這種方法也是通過(guò)看別人發(fā)布的文章解決的,原來(lái)的地址在這:前端 解決筆記本屏幕顯示縮放比例125% 150%對(duì)頁(yè)面布局的影響
我是用的第二種方法,直接就粘過(guò)來(lái)了。
1.在外部創(chuàng)建一個(gè)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是獲取的當(dāng)前屏幕的縮放比,在通過(guò)zoom屬性對(duì)應(yīng)縮放。
zoom屬性用于設(shè)置或檢索對(duì)象的縮放比例。
import { detectZoom } from '@/utils/detectZoom.js';
const m = detectZoom();
document.body.style.zoom = 100 / Number(m);
以上為解決屏幕縮放比的方法,在屏幕分辨率為1920*1080時(shí)可以解決。
二、解決4k屏幕的問(wèn)題
在項(xiàng)目做完之后突然告知需要適配4k屏,并且4k屏的時(shí)候也會(huì)有屏幕縮放比,不想重新改頁(yè)面樣式就想了這個(gè)辦法。也是通過(guò)zoom屬性,原理就是通過(guò)整個(gè)body的縮放使系統(tǒng)的展示區(qū)域變成1920*1080
1.獲取當(dāng)前屏幕的分辨率
獲取屏幕的寬:window.screen.width * window.devicePixelRatio
獲取屏幕的高:window.screen.height * window.devicePixelRatio
2.根據(jù)不同屏幕和縮放比來(lái)調(diào)節(jié)zoom的比例
在main.js中 代碼如下:
import { detectZoom } from '@/utils/detectZoom.js';
const m = detectZoom();
//判斷屏幕是否為4k
if (window.screen.width * window.devicePixelRatio >=3840) {
// switch (m) {
// // 4k屏?xí)r屏幕縮放比為100%
// case 100:
// document.body.style.zoom = 100 / 50;
// break;
// // 4k屏?xí)r屏幕縮放比為125%
// case 125:
// document.body.style.zoom = 100 / 62.5;
// break;
// // 4k屏?xí)r屏幕縮放比為150%
// case 150:
// document.body.style.zoom = 100 / 75;
// break;
// // 4k屏?xí)r屏幕縮放比為175%
// case 175:
// document.body.style.zoom = 100 / 87.4715;
// break;
// // 4k屏?xí)r屏幕縮放比為200%
// case 200:
// document.body.style.zoom = 100 / 100;
// break;
// // 4k屏?xí)r屏幕縮放比為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);
}
最后結(jié)果:雖然屏是4k的,但是系統(tǒng)展示頁(yè)面的可視區(qū)域依舊是1920*1080的,頁(yè)面樣式也沒(méi)有亂。
總結(jié)
到此這篇關(guān)于前端vue按1920*1080設(shè)計(jì)圖的頁(yè)面適配屏幕縮放并適配4K屏的文章就介紹到這了,更多相關(guān)vue頁(yè)面適配屏幕縮放內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
對(duì)vue事件的延遲執(zhí)行實(shí)例講解
今天小編就為大家分享一篇對(duì)vue事件的延遲執(zhí)行實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
uniapp-ios開(kāi)發(fā)之App端與webview端相互通信的方法以及注意事項(xiàng)
在uni-app與Webview之間進(jìn)行數(shù)據(jù)交互是非常常見(jiàn)的需求,下面這篇文章主要給大家介紹了關(guān)于uniapp-ios開(kāi)發(fā)之App端與webview端相互通信的方法以及注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下2024-07-07
關(guān)于應(yīng)用UI組件的移動(dòng)端適配方式
這篇文章主要介紹了關(guān)于應(yīng)用UI組件的移動(dòng)端適配方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
vue3中reactive數(shù)據(jù)被重新賦值后無(wú)法雙向綁定的解決
這篇文章主要介紹了vue3中reactive數(shù)據(jù)被重新賦值后無(wú)法雙向綁定的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05
Vue微信公眾號(hào)網(wǎng)頁(yè)分享的示例代碼
這篇文章主要介紹了Vue微信公眾號(hào)網(wǎng)頁(yè)分享的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
Vuex持久化插件(vuex-persistedstate)解決刷新數(shù)據(jù)消失的問(wèn)題
這篇文章主要介紹了Vuex持久化插件(vuex-persistedstate)-解決刷新數(shù)據(jù)消失的問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-04-04
webpack vue 項(xiàng)目打包生成的文件,資源文件報(bào)404問(wèn)題的修復(fù)方法(總結(jié)篇)
這篇文章主要介紹了解決webpack vue 項(xiàng)目打包生成的文件,資源文件報(bào)404問(wèn)題的修復(fù)方法,需要的朋友可以參考下2018-01-01

