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

vue項(xiàng)目中使用window的onresize事件方式

 更新時(shí)間:2024年08月10日 11:13:55   作者:roongyan92  
這篇文章主要介紹了vue項(xiàng)目中使用window的onresize事件方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue項(xiàng)目使用window的onresize事件

vue項(xiàng)目中使用vue-echars繪制圖表時(shí),需要實(shí)時(shí)根據(jù)窗口大小調(diào)整圖表的大小,我使用的auto-resize屬性,沒有作用,沒有找出錯(cuò)誤在哪里,使用window.onresize事件,必須銷毀才不會報(bào)錯(cuò)哦!

代碼如下:

<template>
    <chart ref="chart1" :options="orgOptions"></chart>
</template>
<script>
export default {
  data() {
    return {
      orgOptions: {}
    };
  },

  created() {
    this.orgOptions = {
      xAxis: {
        type: "category",
        data: ""
      },
      yAxis: {
        type: "value"
      },
      series: [
        {
          data: "",
          type: "line"
        }
      ]
    };
  },
  mounted() {
    /*窗口自適應(yīng),關(guān)鍵代碼*/
    window.onresize = () => {
      this.$refs.chart1.resize();
    };
  },
    //注銷window.onresize事件
  destroyed() {
    window.onresize = null;
  }
}

注意

1、window.onresize事件一般放在created或者mounted生命周期中。

2、window.onresize中的this指向的是window,不是指向vue,如果需要調(diào)用methods中的函數(shù),需要在window.onresize事件的前面把指向vue的this賦值給其他字符,比如"_this";或者使用箭頭函數(shù)。

3、由于window.onresize是全局事件,在其他頁面改變界面時(shí)也會執(zhí)行,這樣可能會出現(xiàn)問題,需要在出這個(gè)界面時(shí)注銷window.onresize事件。

4、window.onresize說明一個(gè)問題:beforeCreate、created、beforeMount、mounted、beforeUpdate、updated中的會觸發(fā)瀏覽器事件需要在destroyed、beforeDestory中銷毀掉。

vue中window.onresize的使用

重點(diǎn):

window.onresize只能在一個(gè)組件中使用,如果多個(gè)組件調(diào)用則會出現(xiàn)覆蓋情況,所以我的解決方案是在App.vue中使用,獲取document.documentElement.clientWidth(即瀏覽器寬度)存放在vuex中,別的組件只需要用computed(計(jì)算屬性)將vuex的clientWidth獲取,然后通過watch監(jiān)聽clientWidth的值,即可觸發(fā)組件事件。

App.vue代碼

<script>
export default {
  name: 'app',
  mounted () {
    window.onresize = () => {
      this.clientWidthResize()
    }
  },
  methods: {
    clientWidthResize () {
      this.$store.commit('Tool/resizeWidth', Number(document.documentElement.clientWidth))
    }
  }
}
</script>

store中tool.js代碼(此處進(jìn)行模塊化開發(fā))

export default {
  namespaced: true,
  state: {
    clientWidth: 0
  },
  getters: {},
  mutations: {
    resizeWidth(state, clientWidth) {
      state.clientWidth = clientWidth;
    },
  },
  actions: {},
}

組件使用

computed: {
  clientWidth () {
    return this.$store.state.Tool.clientWidth || Number(document.documentElement.clientWidth)
  }
},
watch: {
  clientWidth (val) {
    console.log(val)
  }
},

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue-test-utils初使用詳解

    vue-test-utils初使用詳解

    這篇文章主要介紹了vue-test-utils初使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • vue3網(wǎng)絡(luò)請求添加loading過程

    vue3網(wǎng)絡(luò)請求添加loading過程

    這篇文章主要介紹了vue3網(wǎng)絡(luò)請求添加loading過程,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Vue.js實(shí)戰(zhàn)之組件的進(jìn)階

    Vue.js實(shí)戰(zhàn)之組件的進(jìn)階

    組件(Component)是 Vue.js 最強(qiáng)大的功能之一,之前的文章都只是用到了基本的封裝功能,這次將介紹一些更強(qiáng)大的擴(kuò)展。這篇文章主要介紹了Vue.js實(shí)戰(zhàn)之組件進(jìn)階的相關(guān)資料,需要的朋友們可以參考借鑒,下面來一起看看吧。
    2017-04-04
  • Vue?3?表單與后端數(shù)據(jù)交互之查詢并回顯數(shù)據(jù)步驟流程

    Vue?3?表單與后端數(shù)據(jù)交互之查詢并回顯數(shù)據(jù)步驟流程

    本文給大家介紹Vue3表單與后端數(shù)據(jù)交互之查詢并回顯數(shù)據(jù)步驟流程,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-12-12
  • VUE項(xiàng)目調(diào)用高德地圖的詳細(xì)步驟

    VUE項(xiàng)目調(diào)用高德地圖的詳細(xì)步驟

    要在Web頁面中加入地圖,我推薦你使用高德地圖JSAPI,下面這篇文章主要給大家介紹了關(guān)于VUE項(xiàng)目調(diào)用高德地圖的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • Vue路由權(quán)限控制解析

    Vue路由權(quán)限控制解析

    這篇文章主要介紹了Vue路由權(quán)限控制的相關(guān)資料,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-11-11
  • 淺談針對Vue相同路由不同參數(shù)的刷新問題

    淺談針對Vue相同路由不同參數(shù)的刷新問題

    這篇文章主要介紹了淺談針對Vue相同路由不同參數(shù)的刷新問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • 老生常談vue3組件通信方式

    老生常談vue3組件通信方式

    這篇文章主要介紹了vue3組件通信方式,面試題經(jīng)常會問到vue3組件間的通信方式,今天就通過實(shí)例代碼給大家詳細(xì)介紹下,對vue3組件通信相關(guān)知識感興趣的朋友一起看看吧
    2022-08-08
  • vue插件draggable實(shí)現(xiàn)拖拽移動圖片順序

    vue插件draggable實(shí)現(xiàn)拖拽移動圖片順序

    這篇文章主要為大家詳細(xì)介紹了vue插件draggable實(shí)現(xiàn)拖拽移動圖片順序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • 關(guān)于Vue中echarts響應(yīng)式頁面變化resize()的用法介紹

    關(guān)于Vue中echarts響應(yīng)式頁面變化resize()的用法介紹

    Vue項(xiàng)目中開發(fā)數(shù)據(jù)大屏,使用echarts圖表根據(jù)不同尺寸的屏幕進(jìn)行適配,resize()可以調(diào)用echarts中內(nèi)置的resize函數(shù)進(jìn)行自適應(yīng)縮放,本文將給大家詳細(xì)介紹resize()的用法,需要的朋友可以參考下
    2023-06-06

最新評論