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

Vue實現(xiàn)實時監(jiān)聽頁面寬度高度變化

 更新時間:2024年03月27日 15:32:51   作者:嫣嫣細語  
這篇文章主要為大家詳細介紹了Vue如何實現(xiàn)實時監(jiān)聽頁面寬度高度變化,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下

vue監(jiān)聽頁面寬高

運用的主要技術:watch監(jiān)聽

話不多說直接上代碼,自行研究

 <template>
  <div class="rightContainer">
    <h1>監(jiān)聽頁面寬高</h1>
    <h2>當前整個頁面寬度{{ windowWidth }}px</h2>
    <h2>當前整個頁面高度{{ windowHeight }}px</h2>
  </div>
</template>
<script>
export default {
  name: 'WatchsHW',
  data() {
    return {
      windowHeight: document.body.clientHeight,
      windowWidth: document.body.clientWidth
    }
  },
  watch: {
    // 監(jiān)聽頁面高度
    windowHeight(val) {
      console.log('實時屏幕高度:', val, this.windowHeight)
    },
    // 監(jiān)聽頁面寬度
    windowWidth(val) {
      console.log('實時屏幕寬度:', val, this.windowHeight)
    }
 
  },
 
  mounted() {
    // <!--把window.onresize事件掛在到mounted函數(shù)上-->
    window.onresize = () => {
      return (() => {
        this.windowHeight = document.documentElement.clientHeight // 高
        this.windowWidth = document.documentElement.clientWidth // 寬
      })()
    }
  },
 
  methods: {
 
  }
}
</script>
 
<style lang="scss" scoped>
.rightContainer{
  width: 100%;
  text-align: center;
  overflow: hidden;
}
</style>
 

知識補充

除了上文的方法,小編還為大家整理了一些Vue實時監(jiān)聽的其他方法,希望對大家有所幫助

Watch

watch的作用可以監(jiān)控一個值的變換,并調(diào)用因為變化需要執(zhí)行的方法??梢酝ㄟ^watch動態(tài)改變關聯(lián)的狀態(tài)。

簡單點說,就是實時監(jiān)聽某個數(shù)據(jù)的變化。

1、普通監(jiān)聽

<template>
<!-- 監(jiān)聽屬性 -->
  <div>
    <p>{{num}}</p>
    <button @click="num++">按鈕</button>
  </div>
</template>

<script>
export default {
  data () {
    return {
      num:30
 
    }
  },
  watch:{
    // 第1種格式:
    // num(newVal,oldVal){
    //   // 什么時候執(zhí)行, num的值發(fā)生變化的時候,就執(zhí)行這里的代碼
    //   console.log("num被修改了",newVal,oldVal);
    // },
    // 第2種格式:
    num:{
      handler(newVal,oldVal){
        // 什么時候執(zhí)行, num的值發(fā)生變化的時候,就執(zhí)行這里的代碼
        console.log("num被修改了",newVal,oldVal);
      }
    }
  }
}
</script>
 
<style lang = "less" scoped>
  
</style>

2、立即監(jiān)聽

如果我們需要在最初綁定值的時候也執(zhí)行函數(shù),則就需要用到immediate屬性。

<template>
<!-- 立即監(jiān)聽 -->
  <div>
    <p>{{num}}</p>
    <button @click="num++">按鈕</button>
  </div>
</template>

<script>
export default {
  data () {
    return {
      num:30
 
    }
  },
  watch:{
    num:{
      handler(newVal,oldVal){
        // 什么時候執(zhí)行, num的值發(fā)生變化的時候,就執(zhí)行這里的代碼
        console.log("num被修改了",newVal,oldVal);
      },
      immediate:true   // 立即監(jiān)聽
    }
  }
}
</script>
 
<style lang = "less" scoped>
  
</style>

immediate需要搭配handler一起使用,其在最初綁定時,調(diào)用的函數(shù)也就是這個handler函數(shù)。

3、深度監(jiān)聽

當需要監(jiān)聽一個對象的改變時,普通的watch方法無法監(jiān)聽到對象內(nèi)部屬性的改變,只有data中的數(shù)據(jù)才能夠監(jiān)聽到變化,此時就需要deep屬性對對象進行深度監(jiān)聽。

<template>
<!-- 深度監(jiān)聽 -->
  <div>
    <p>{{obj.age}}</p>
    <button @click="obj.age++">按鈕</button>
  </div>
</template>

<script>
export default {
  data () {
    return {
      obj:{
        name:"Vue",
        age:7
      }
 
    }
  },
  watch:{
    // obj:{
    //   handler(newVal,oldVal){
    //     // 什么時候執(zhí)行, obj中一旦有屬性發(fā)生變化,就會執(zhí)行這里的代碼
    //     console.log("name或者age被修改了",newVal,oldVal);
    //   },
    //   deep:true
    // }

    "obj.age":{
      handler(newVal,oldVal){
        // 什么時候執(zhí)行, age被修改的時候來執(zhí)行
        console.log("age被修改了",newVal,oldVal);
      },
    }
  }
}
</script>
 
<style lang = "less" scoped>
  
</style>

注意:

1、如果監(jiān)聽的數(shù)據(jù)是一個對象,那么 immediate: true失效;

2、一般使用于對引用類型的監(jiān)聽,深度監(jiān)聽,如監(jiān)聽一個Object,只要Object里面的任何一個字段發(fā)生變化都會被監(jiān)聽,但是比較消耗性能,根據(jù)需求使用,能不用則不用。

3、因為上面代碼obj是引用數(shù)據(jù)類型,val, oldVal指向一致,導致看到的結(jié)果一樣。

4、deep優(yōu)化

我們可以通過點語法獲取對象中的屬性,然后轉(zhuǎn)為字符串,即是對深度監(jiān)聽的優(yōu)化

<template>
  <div class="home">
    <h3>{{obj.age}}</h3>
    <button @click="btnClick">按鈕</button>
  </div>
</template>

<script>
export default {
  name: "Home",
  data() {
    return {
      obj: {
        name: "Lucy",
        age: 13
      }
    };
  },
  methods: {
    btnClick() {
      this.obj.age = 33;
    }
  },
  watch: {
    // 通過點語法獲取對象中的屬性,然后轉(zhuǎn)為字符串,即是對深度監(jiān)聽的優(yōu)化
    "obj.age": {
      handler(val, oldVal) {
        console.log(val, oldVal);
      },
      deep: true,
      immediate: true,		// 此時監(jiān)聽的數(shù)據(jù)不是一個對象,可以使用immediate
    }
  }
};
</script>

到此這篇關于Vue實現(xiàn)實時監(jiān)聽頁面寬度高度變化的文章就介紹到這了,更多相關Vue實時監(jiān)聽頁面寬高內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue axios sessionID每次請求都不同的原因以及修改方式

    vue axios sessionID每次請求都不同的原因以及修改方式

    這篇文章主要介紹了vue axios sessionID每次請求都不同的原因以及修改方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • vue 使用element-ui中的Notification自定義按鈕并實現(xiàn)關閉功能及如何處理多個通知

    vue 使用element-ui中的Notification自定義按鈕并實現(xiàn)關閉功能及如何處理多個通知

    這篇文章主要介紹了vue 使用element-ui中的Notification自定義按鈕并實現(xiàn)關閉功能及如何處理多個通知,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • VueJs中toRef與toRefs函數(shù)對比詳解

    VueJs中toRef與toRefs函數(shù)對比詳解

    這篇文章主要為大家介紹了VueJs中toRef與toRefs函數(shù)對比詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • elementui中el-row的el-col排列混亂問題及解決

    elementui中el-row的el-col排列混亂問題及解決

    這篇文章主要介紹了elementui中el-row的el-col排列混亂問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 這15個Vue指令,讓你的項目開發(fā)爽到爆

    這15個Vue指令,讓你的項目開發(fā)爽到爆

    這篇文章主要介紹了這15個Vue指令,讓你的項目開發(fā)爽到爆,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-10-10
  • 詳解新手使用vue-router傳參時注意事項

    詳解新手使用vue-router傳參時注意事項

    這篇文章主要介紹了詳解新手使用vue-router傳參時注意事項,詳細的介紹了幾種常見錯誤,需要的朋友們下面隨著小編來一起學習學習吧
    2019-06-06
  • Vue使用echarts的完整步驟及解決各種報錯

    Vue使用echarts的完整步驟及解決各種報錯

    最近在項目中需要對數(shù)據(jù)進行可視化處理,而眾所周知echarts是非常強大的插件,下面這篇文章主要給大家介紹了關于Vue使用echarts的完整步驟及解決各種報錯的相關資料,需要的朋友可以參考下
    2022-05-05
  • Vue.Js中的$watch()方法總結(jié)

    Vue.Js中的$watch()方法總結(jié)

    這篇文章主要給大家介紹了在Vue.Js中的$watch()方法的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • vue3+ts+vite2項目實戰(zhàn)踩坑記錄

    vue3+ts+vite2項目實戰(zhàn)踩坑記錄

    最近嘗試上手Vue3+TS+Vite,對比起Vue2有些不適應,但還是真香,下面這篇文章主要給大家介紹了關于vue3+ts+vite2項目的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-09-09
  • Vue?如何關掉響應式問題

    Vue?如何關掉響應式問題

    這篇文章主要介紹了Vue?如何關掉響應式問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09

最新評論