
效果图:

先清楚两个东西,浏览器窗口的缩放和项目侧边栏折叠后窗口的缩放,这两个是不一样的
第一种,浏览器窗口缩放后,当前窗口会放大了或者缩小了,这时会走浏览器缩放的代码部分,
第二种,而项目侧边栏折叠后窗口的缩放,虽然项目里面的窗口缩放了,但是,浏览器的窗口并没有发生变化,所有这时不会走浏览器缩放的代码部分,
详细说一下第二种情况:

当侧边栏折叠后,

可以发现,这两个图的大小都是左边侧边栏加右边的内容部分,总体的大小没有发生变化,所以它不会走浏览器的缩放方法
但是他们两个之间相对发生了缩放,
解决方法:
浏览器窗口缩放,这种很好解决,
第一种方法:
window.addEventListener('resize', () => {this.myChart.resize()
})
第二种方法:
window.onresize = () => {this.myChart.resize()
}
一般都是用第一种 addEventListener 去监听缩放
重点就是第二种情况,浏览器没有缩放,侧边栏和内容相对缩放
这种情况我也看到了很多解决方法,但都有利有弊吧
第一种方法:
一个插件,但是我用了感觉哈,如果你是一个图表,马马虎虎可以用,如果有二三四五六个图表,那页面就卡成ppt了,懂得都懂
插件名好像是element-resize-detector,自己去搜索改怎么用,我就不说了
第二种方法:
如果你是用vue+admin的后台管理模板的话,里面有写好的方法,可以自己抠出来用,有点难,牵扯的东西太多了
第三种方法:
目前我所用的方法,单个图表或者多个图表都可用
首先侧边栏折叠的代码
这个官网都有案例的,直接拿过来修改一下就好了,
// 折叠/展开侧边栏collapseClk() {if (this.isCollapse) {this.isCollapse = falsethis.collapseClass = 'el-icon-s-fold'} else {this.isCollapse = truethis.collapseClass = 'el-icon-s-unfold'}this.$store.commit('IS_COLLAPSE', this.isCollapse)},
注: 如果折叠的时候没有动画,那就是侧边栏的宽度没有设置,
// 侧边栏折叠宽度
.el-menu-vertical-demo:not(.el-menu--collapse) {width: 200px;min-height: 400px;
}
这里主要是获取折叠或者展示时的状态, this.$store.commit(‘IS_COLLAPSE’, this.isCollapse) 将它存储到全局中,然后在其他页面监听是否折叠来判断图表是否resize
在页面中应用:
a.vue
watch: {'$store.state.isCollapse': {handler(newVal, oldVal) {setTimeout(() => {this.myChart.resize()}, 500)},},},mounted() {this.myChart = this.$echarts.init(document.getElementById('emain'))this.myChart.showLoading({ text: '加载中', color: '#fee', maskColor: 'rgba(0 ,0 ,0 ,0.2 )', zlevel: 0 })this.charts()},methods:{charts(){xxxxx().then((data) => {//获取接口返回值this.myChart.clear()this.myChart.setOption(this.option)this.myChart.setOption({xAxis: {data: xxx,},series: [{data: xxx,},],})this.myChart.hideLoading()window.addEventListener('resize', () => {this.myChart.resize()})})}}
如果是多个图表的话也是一样的,循环resize就可以了
watch: {'$store.state.isCollapse': {handler(newVal, oldVal) {setTimeout(() => {for (var i = 0; i < charts.length; i++) {charts[i].resize()}}, 500)},},},
ok,没了,哪里写的不对还请指出,谢谢,下期再见! ! !