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

Vue檢測屏幕變化來改變不同的charts樣式實例

 更新時間:2020年10月26日 09:15:49   作者:GllWyz  
這篇文章主要介紹了Vue檢測屏幕變化來改變不同的charts樣式實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

css中我們經常會通過媒體查詢就可以完成對不同的屏幕展現(xiàn)不同的樣式

在js中我們也可以通過檢測屏幕的變化來展現(xiàn)不同的樣式

在我的實例中:因為第一次打開也不知道到底是應該展示哪一個屏幕,所以會進行先判斷一次,之后用addEventListener來是實現(xiàn)功能,暫時是通過這種方式實現(xiàn)的,以后有更好的方法再更新。。。

 mounted() {
  this.checkScreen()
 },
methods: {
 // 屏幕檢測變化
  checkScreen() {
   var _this = this
   if (document.body.clientWidth > 500) {
     _this.echartsOne()
   } else {
     _this.echartsTwoPhone()
   }
   window.addEventListener('resize', () => {
     if (document.body.clientWidth < 500) {
      _this.echartsTwoPhone()
     } else {
      _this.echartsOne()
     }
   })
  }
}

補充知識:vue中處理echarts因v-if切換后圖形顯示異常+實現(xiàn)echarts監(jiān)聽窗口變化而改變大小

一、處理echarts因v-if切換后圖形顯示異常

有時候我們需要在一個頁面中使用v-if來顯示不同的兩個圖表。

視覺效果上好像是從一個頁面點擊鏈接跳轉到另一個頁面,但其實原理是通過銷毀和重建兩個不同dom容器來實現(xiàn)這個效果。

可能會出現(xiàn)的問題:

在切換到另一個圖表顯示的時候,改變了窗口寬度高度,那么點擊返回按鈕時看到原先的echarts圖形就會有一部分消失顯示不完整了。

解決辦法:

我們需要在返回這個按鈕上加個定時器延遲,來主動觸發(fā)窗口發(fā)生變化(前提是代碼也有做監(jiān)聽窗口變化改變圖形大小的操作,下面標題二會講解)。這樣圖形能正確自動渲染變化一次。

methods: {
 // 關閉監(jiān)控ip執(zhí)行詳情頁
  closePerfExe () {   
   this.isShowPerfExe = false // 控制當前dom容器的顯示
   // 當在監(jiān)控ip詳情頁點擊回性能分析頁的時候,加個延遲主動觸發(fā)窗口變化,這樣窗口改變性能分析頁就不會發(fā)生圖表顯示不完整的情況了
   // 這里的代碼是關鍵?。。?
   setTimeout( () => {
    let triggerResize = new Event('resize')
    window.dispatchEvent(triggerResize)
   },0)
  }
}

二、vue實現(xiàn)echarts監(jiān)聽窗口變化而改變大小

監(jiān)聽窗口的變化,echarts圖形大小跟著變化。

注意:在組件銷毀時記得也要移除監(jiān)聽。

data () {
 return {
 myChartPerformance: '', // echarts的dom容器
 performanceOption: '' // echarts配置項option
 } 
 },
 mounted () {
  // 一般我為了防止出現(xiàn)一些切換問題,都是先清除echarts再初始化
    if(this.myChartPerformance){
     this.myChartPerformance.clear()
    }
    this.myChartPerformance = echarts.init(document.getElementById('myChartPerformance'))

  // 圖表數(shù)據(jù)配置
    this.performanceOption = {
    title: {
     text: chartOptions.titleName
    },
    tooltip: {
     trigger: 'axis'
    },
    //.........
    //.........
   }
   // 設置圖表數(shù)據(jù)配置
   this.myChartPerformance.setOption(this.performanceOption)
  // 監(jiān)聽窗口大小改變圖表大?。ㄏ纫瞥俦O(jiān)聽,防止出錯)
   window.removeEventListener('resize', this.resizePerformanceFun)
   window.addEventListener('resize', this.resizePerformanceFun)
 },
 beforeDestroy () {
  // 組件銷毀前移除監(jiān)聽
 window.removeEventListener('resize', this.resizePerformanceFun)
 },
 methods : {
 resizePerformanceFun () {
    if(this.myChartPerformance){
    // console.log('窗口改變了,重新渲染圖形')
    this.myChartPerformance.resize()
   }
  }
}

以上這篇Vue檢測屏幕變化來改變不同的charts樣式實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue項目實現(xiàn)便捷接入百度地圖API

    vue項目實現(xiàn)便捷接入百度地圖API

    部分項目需要地圖的嵌入,這篇文章主要介紹了vue項目中調用百度地圖API使用方法,其他的地圖調用與之類似,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2022-04-04
  • Vue自定義圖片懶加載指令v-lazyload詳解

    Vue自定義圖片懶加載指令v-lazyload詳解

    這篇文章主要為大家詳細介紹了Vue自定義圖片懶加載指令v-lazyload,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • VUE DOM加載后執(zhí)行自定義事件的方法

    VUE DOM加載后執(zhí)行自定義事件的方法

    今天小編就為大家分享一篇VUE DOM加載后執(zhí)行自定義事件的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue報錯"Failed?to?resolve?loader:less-loader"的解決方法

    Vue報錯"Failed?to?resolve?loader:less-loader"的解決方

    這篇文章主要給大家介紹了關于Vue報錯"Failed?to?resolve?loader:less-loader"的解決方法,文中通過圖文介紹的非常詳細,對同樣遇到這樣問題的朋友具有一定的需要的朋友可以參考下
    2023-02-02
  • 淺談vue中關于checkbox數(shù)據(jù)綁定v-model指令的個人理解

    淺談vue中關于checkbox數(shù)據(jù)綁定v-model指令的個人理解

    這篇文章主要介紹了淺談vue中關于checkbox數(shù)據(jù)綁定v-model指令的個人理解,v-model用于表單的數(shù)據(jù)綁定很常見,下面就來詳細的介紹一下
    2018-11-11
  • vue2.0 computed 計算list循環(huán)后累加值的實例

    vue2.0 computed 計算list循環(huán)后累加值的實例

    下面小編就為大家分享一篇vue2.0 computed 計算list循環(huán)后累加值的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue動態(tài)組件之:is在組件中的使用場景

    vue動態(tài)組件之:is在組件中的使用場景

    這篇文章主要介紹了vue動態(tài)組件之:is在組件中的使用場景,本文結合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • Vue3.x中使用element-plus的各種方式詳解

    Vue3.x中使用element-plus的各種方式詳解

    這篇文章主要介紹了Vue3.x中使用element-plus的各種方式詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 在vue項目中安裝使用Mint-UI的方法

    在vue項目中安裝使用Mint-UI的方法

    Mint UI 是 由餓了么前端團隊推出的 一個基于 Vue.js 的移動端組件庫,下面通過本文給大家介紹在vue項目中安裝使用Mint-UI的方法,需要的朋友參考下吧
    2017-12-12
  • vue yaml代碼編輯器組件問題

    vue yaml代碼編輯器組件問題

    這篇文章主要介紹了vue yaml代碼編輯器組件問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07

最新評論