VUE學(xué)習(xí)筆記(三)大屏自適應(yīng)的幾種方法

1.自適屏幕糖儡,始終保持16:9的比例

<!-- 大屏固定比例16:9自適應(yīng)   -->
<template>
    <div class="container">
      <div class="content" :style="getAspectRatioStyle">
        <!-- 數(shù)據(jù)展示內(nèi)容 -->
      </div>
    </div>
  </template>
   
  <script setup lang="ts">
  import { ref, onMounted, onBeforeUnmount, computed } from 'vue';
      const contentWidth = ref(0);
      const contentHeight = ref(0);
   
      const calculateAspectRatio = () => {
        const container = document.querySelector('.container');
        // const containerWidth = container.offsetWidth;
        const containerWidth: number = (<HTMLElement>container).offsetWidth;
        // const containerHeight = container.offsetHeight;
        const containerHeight: number = (<HTMLElement>container).offsetHeight;
   
        const aspectRatio = 16 / 9; // 16:9 比例
        const containerAspectRatio = containerWidth / containerHeight;
   
        if (containerAspectRatio > aspectRatio) {
          // 以高度為基準(zhǔn)擅威,按比例計(jì)算寬度
          contentHeight.value = containerHeight;
          contentWidth.value = Math.floor(containerHeight * aspectRatio);
        } else {
          // 以寬度為基準(zhǔn)篱瞎,按比例計(jì)算高度
          contentWidth.value = containerWidth;
          contentHeight.value = Math.floor(containerWidth / aspectRatio);
        }
        console.log('contentWidth',contentWidth.value)
        console.log('contentHeight',contentHeight.value)
      };
   
      onMounted(() => {
        calculateAspectRatio();
        window.addEventListener('resize', calculateAspectRatio);
      });
   
      onBeforeUnmount(() => {
        window.removeEventListener('resize', calculateAspectRatio);
      });
   
      const getAspectRatioStyle = computed(() => ({
        width: `${contentWidth.value}px`,
        height: `${contentHeight.value}px`,
        margin: 'auto',
        background: 'gray'
      }
    ));
   

  </script>
   
  <style>
  .container {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
   
  .content {
    /* 根據(jù)計(jì)算得到的寬高樣式設(shè)置 */
  }
  </style>

2.使用CSS scale屬性對大屏幕做自適應(yīng)處理

<template>
<div class="login-container">
  <div class="login-main" ref="dataScreenRef"></div>
</div>

</template>
<script setup>
const dataScreenRef = ref(null);
const width = 1920;
const height = 1080;

// 根據(jù)瀏覽器大小推斷縮放比例
// 首先要確定設(shè)計(jì)稿尺寸铭腕,默認(rèn)是 1920 x 1080
// 分別計(jì)算瀏覽器和設(shè)計(jì)圖寬高比
// 如果瀏覽器的寬高比大于設(shè)計(jì)稿的寬高比器钟,就取瀏覽器高度和設(shè)計(jì)稿高度之比
// 如果瀏覽器的寬高比小于設(shè)計(jì)稿的寬高比斑司,就取瀏覽器寬度和設(shè)計(jì)稿寬度之比
const getScale = (w = width, h = height) => {
  let ww = window.innerWidth / w;
  let wh = window.innerHeight / h;
  return ww < wh ? ww : wh;
};
/* 瀏覽器監(jiān)聽 resize 事件 */
const resize = () => {
  if (dataScreenRef.value) {
    dataScreenRef.value.style.transform = `scale(${getScale()}) translate(-50%, -50%)`;
  }
};

onMounted(() => {
  // 初始化時(shí)為外層盒子加上縮放屬性谴餐,防止刷新界面時(shí)就已經(jīng)縮放
  if (dataScreenRef.value) {
    dataScreenRef.value.style.transform = `scale(${getScale()}) translate(-50%, -50%)`;
    dataScreenRef.value.style.width = `${width}px`;
    dataScreenRef.value.style.height = `${height}px`;
  }
  window.addEventListener("resize", resize);
});


</script>
<style scoped lang="scss">
.login-container {
  width: 100%;
  height: 100%;
  transform-origin: 0 0;
  position: relative;
}
.login-main {
  width: 100%;
  height: 100%;
  position: absolute;
}

</style>

3.使用rem

(1)npm下載插件,自動(dòng)將px單位轉(zhuǎn)換成rem單位

npm install postcss-px2rem --save

(2)在根目錄src中新建util目錄下新建rem.js等比適配文件

// rem等比適配配置文件
// 基準(zhǔn)大小
const baseSize = 14
// 設(shè)置 rem 函數(shù)
function setRem () {
  // 當(dāng)前頁面寬度相對于 1920寬的縮放比例姻政,可根據(jù)自己需要修改。
  const scale = document.documentElement.clientWidth / 1920
  // 設(shè)置頁面根節(jié)點(diǎn)字體大衅裆ぁ(“Math.min(scale, 2)” 指最高放大比例為2汁展,可根據(jù)實(shí)際業(yè)務(wù)需求調(diào)整)
  document.documentElement.style.fontSize = baseSize * Math.min(scale, 2) + 'px'
}
// 初始化
setRem()
// 改變窗口大小時(shí)重新設(shè)置 `rem`
window.onresize = function () {
  setRem()
}

(3)在main.js中引入適配文件

import './util/rem'

(4)到vue.config.js中配置插件

 
// 引入等比適配插件
const px2rem = require('postcss-px2rem')
 
// 配置基本大小
const postcss = px2rem({
  // 基準(zhǔn)大小 baseSize,需要和rem.js中相同
  // remUnit: 14 代表 1rem = 14px; 所以當(dāng)你一個(gè)14px值時(shí)厌殉,它會自動(dòng)轉(zhuǎn)成 (14px/14)rem
  remUnit: 14
})
 
// 使用等比適配插件
module.exports = {
  lintOnSave: true,
  css: {
    loaderOptions: {
      less: {
        javascriptEnabled: true,
      },
      postcss: {
        plugins: [
          postcss,
        ],
      },
    },
  },
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末食绿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子公罕,更是在濱河造成了極大的恐慌器紧,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件楼眷,死亡現(xiàn)場離奇詭異铲汪,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)罐柳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進(jìn)店門掌腰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人张吉,你說我怎么就攤上這事齿梁。” “怎么了肮蛹?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵勺择,是天一觀的道長。 經(jīng)常有香客問我蔗崎,道長酵幕,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任缓苛,我火速辦了婚禮芳撒,結(jié)果婚禮上邓深,老公的妹妹穿的比我還像新娘。我一直安慰自己笔刹,他們只是感情好芥备,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著舌菜,像睡著了一般萌壳。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上日月,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天袱瓮,我揣著相機(jī)與錄音,去河邊找鬼爱咬。 笑死尺借,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的精拟。 我是一名探鬼主播燎斩,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼蜂绎!你這毒婦竟也來了栅表?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤师枣,失蹤者是張志新(化名)和其女友劉穎怪瓶,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體坛吁,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡劳殖,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了拨脉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片哆姻。...
    茶點(diǎn)故事閱讀 39,785評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖玫膀,靈堂內(nèi)的尸體忽然破棺而出矛缨,到底是詐尸還是另有隱情,我是刑警寧澤帖旨,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布箕昭,位于F島的核電站,受9級特大地震影響解阅,放射性物質(zhì)發(fā)生泄漏落竹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一货抄、第九天 我趴在偏房一處隱蔽的房頂上張望述召。 院中可真熱鬧朱转,春花似錦、人聲如沸积暖。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽夺刑。三九已至缅疟,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間遍愿,已是汗流浹背存淫。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留沼填,地道東北人纫雁。 一個(gè)月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像倾哺,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子刽脖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內(nèi)容