面试篇-vue中第三方库的使用(echarts)

文章目录

Echarts

基本用法:

  • 初始化类: echarts.init(domId)
  • 样式配置: option={}
  • 渲染图展: myChart.setOption(option)

一、vue2和vue3中使用

1、安装echarts

bash 复制代码
npm install echarts --save

vue2中引入与 使用

main.js引入

js 复制代码
import Vue from "vue";
import App from "./App.vue";
import * as echarts from "echarts";
Vue.prototype.$echarts = echarts;

vue页面中使用

html 复制代码
<div id="myChart" style="width: 500px;height: 500px"></div>
 
<script>
export default{
  mounted() {
      let myChart = this.$echarts.init(document.getElementById("myChart"));
      myChart.setOption({
        tooltip: {},
        xAxis: {
            data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子']
        },
        yAxis: {},
        series: [
          {
            name: "销量",
            type: "bar",
            data: [5, 20, 36, 10, 10, 20, 20, 36, 10, 10, 20],
          },
        ]
      });
  },
}
</script>

vue3中引入与 使用

引入方法一: 通过getCurrentInstance全局引入
main.js引入

js 复制代码
import { createApp } from 'vue'
import * as echarts from 'echarts'   //主要代码
import App from './App.vue'
const app =  createApp(App)
app.config.globalProperties.$echarts = echarts      //主要代码
app.mount('#app')

vue页面中使用

html 复制代码
<div id="myChart" style="width: 200px; height:300px; "></div>
 
<script lang="ts" setup>
const echarts = getCurrentInstance()?.appContext.config.globalProperties.$echarts;
 
function as() {
  const myChart = echarts.init(document.getElementById("myChart"));
  // 绘制图表
  myChart.setOption({
    tooltip: {},
    xAxis: {
      data: ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"],
    },
    yAxis: {},
    series: [
      {
        name: "销量",
        type: "bar",
        data: [5, 20, 36, 10, 10, 20, 20, 36, 10, 10, 20],
      },
    ],
  });
}
onMounted(() => {
 
  nextTick(() => {
    as();
  });
});
</script>

引入方法二: 仅在组件内部引入及使用

html 复制代码
<script lang="ts" setup>
import * as echarts from 'echarts'
 
function as() {
  const myChart = echarts.init(document.getElementById("myChart"));  //主要语句
 
  myChart.setOption({
    tooltip: {},
    xAxis: {
      data: ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"],
    },
    yAxis: {},
    series: [
      {
        name: "销量",
        type: "bar",
        data: [5, 20, 36, 10, 10, 20, 20, 36, 10, 10, 20],
      },
    ],
  });
}
 
onMounted(() =>{
  nextTick(() => {
     
  })
});
 
</script>

二、相关面试题

1、vue2 vue3使用echarts无法二次渲染、echarts无法渲染、echarts图标不显示

销毁div重新渲染:

js 复制代码
$("#myChart").removeAttr("_echarts_instance_");
// 或
$("#myChart").removeAttr("_echarts_instance_").empty();

2、切换其他组件统计图时,出现卡顿如何解决

卡顿的原因: 每个图例在没有数据时 会创建一个定时器去渲染气泡 ,页面切换后,图例销毁了 ,但echarts实例还在内存 ,气泡渲染定时器仍在运行 ,导致echarts占用CPU高,卡顿

解决方案mounteddestroy间加一个beforeDestroy释放该页面的echart资源

js 复制代码
mounted(){}
beforeDestroy(){
	//清空图例数据,不影响图例resize,释放内存
	this.chart.clear()
}
destroy(){}

3、echarts图标自适应div问题

div发生resize事件 时,让其触发echarts的resize事件

javascript 复制代码
$('.chart').resize(function(){
	myChart.resize()
})
//若jquery的resize不生效,引入`jquery.ba-resize.js`
相关推荐
\xin15 分钟前
pikachu自编CSRF(GET),CSRF(POST),CSRF(token)
前端·csrf
是大强17 分钟前
前端一个项目用node20 一个项目用node14 怎么切换
前端
不老刘24 分钟前
Git Cherry-Pick:微前端架构下的“精准医疗”与最佳实践
前端·git
LIO1 小时前
ESLint 极简指南:让代码既规范又一致
前端·eslint
明月_清风1 小时前
前端工程化七连问:从紧急修复到版本控制,一文打通工程化任督二脉
前端·前端工程化
用户6757049885021 小时前
不装插件不写代码!教你一招搞定网页长截图!清晰且高效!
前端·chrome
tjl521314_211 小时前
01C++ 分离编译与多文件编程
前端·c++·算法
sayamber1 小时前
vLLM 容器化部署实战:如何在云服务器上跑起高并发大模型推理服务
前端
LIO1 小时前
Pinia 极简指南:Vue 3 官方状态管理库
前端·vue.js
燐妤2 小时前
前端HTML编程2:深入学习表单与表格
前端·学习·html5