37-Vue之ECharts高级-交互API

简介: 37-Vue之ECharts高级-交互API

前言

  • 本篇来学习下ECharts中交互API的使用

全局ECharts对象

  • 全局 echarts 对象是引入 echarts.js 文件之后就可以直接使用的
  1. init :初始化ECharts实例对象,使用主题
  2. registerTheme:注册主题
echarts.registerTheme('CustomTheme', {
        "color": [
            "#5470c6",
            "#91cc75",
            "#fac858",
            "#ee6666",
            "#73c0de",
            "#3ba272",
            "#fc8452",
            "#9a60b4",
            "#ea7ccc"
        ],
  1. registerMap:注册地图数据
  2. connect:实现多图关联,传入联动目标为 EChart 实例,支持数组
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>全局ECharts对象</title>
    <!-- cdn方式 引入echarts.js文件 -->
    <script src="https://cdn.jsdelivr.net/npm/echarts@5.4.1/dist/echarts.min.js"></script>
    <!-- 引入自定义主题-->
    <script src="lib/CustomTheme.js"></script>
    <!--引入jquery-->
    <script src="lib/jquery.min.js"></script>
</head>
<body>
<!-- 准备一个呈现图表的盒子 -->
<div id='app' style="width: 600px;height: 400px;border: 1px solid deeppink"></div>
<div id='map' style="width: 600px;height: 400px;border: 1px solid blueviolet"></div>
<script>
    // init 初始化echarts实例对象 并设置主题
    var myCharts = echarts.init(document.getElementById('app'), 'CustomTheme')
    var xDataArr = ['张三', '李四', '王五', '大明白', '小糊涂'] // x轴数据
    var yDataArr = [88, 92, 63, 77, 94]  // y轴数据
    var option = {
        toolbox: {
            feature: {
                saveAsImage: {}
            }
        },
        xAxis: {
            type: 'category',
            data: xDataArr
        },
        yAxis: {
            type: 'value'
        },
        series: [
            {
                name: '分数',
                type: 'bar',  // 图表类型  bar:柱状图   line:折线图   pie:饼图
                data: yDataArr,
                markPoint: {   // 标记最大最小值
                    data: [
                        {type: 'max', name: '最大值'},
                        {type: 'min', name: '最小值'}
                    ]
                },
                markLine: {
                    data: [
                        {
                            type: 'average', name: '平均值'
                        }
                    ]
                },
                label: {
                    show: true,  // 柱状图显示数值
                    rotate: 30, // 值旋转角度
                },
                barWidth: '30%' // 柱的宽度
            }
        ]
    }
    myCharts.setOption(option)
    var myCharts2 = echarts.init(document.getElementById("map"))
    // json/map/china.json 为本地的地图矢量数据
    $.get('json/map/china.json', function (chinaJson) {
        console.log(chinaJson) // chinaJson 地图矢量数据
        // registerMap :注册地图矢量数据  
        echarts.registerMap('chinaMap', chinaJson)
        var option = {
            geo: {
                type: 'map',// map是一个固定的值 类型
                map: 'chinaMap',//chinaMap需要和registerMap中的第一个参数保持一致
                roam: true, // 设置允许缩放以及拖动的效果
                label: {
                    show: true // 展示标签
                },
                zoom: 1, // 设置初始化的缩放比例
            }
        }
        myCharts2.setOption(option)
        // connect : 实现多图关联
        echarts.connect([myCharts, myCharts2])
    })
</script>
</body>
</html>
  • 多图联动保存的图片

echartsInstance对象

eChartsInstance 对象是通过 echarts.init 方法调用之后得到的实例对象

  • setOption
  • 设置或修改图表实例的配置项以及数据
  • 多次调用setOption方法
    合并新的配置和旧的配置
    增量动画
  • resize : 重新计算和绘制图表
window.onresize = function(){
  myChart.resize();
}
  • on/off:绑定或者解绑事件处理函数
  • 鼠标事件
  • 常见事件: ‘click’、‘dblclick’、‘mousedown’、‘mousemove’、‘mouseup’
  • ECharts 事件
  • legendselectchanged、‘datazoom’、‘pieselectchanged’、‘mapselectchanged’
  • dispatchAction: 主动触发某些行为, 使用代码模拟用户的行为
  • clear:清空当前实例,会移除实例中所有的组件和图表;清空之后可以再次 setOption
  • dispose:销毁实例;销毁后实例无法再被使用
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>echartsInstance对象</title>
    <!-- cdn方式 引入echarts.js文件 -->
    <script src="https://cdn.jsdelivr.net/npm/echarts@5.4.1/dist/echarts.min.js"></script>
    <script src="lib/jquery.min.js"></script>
</head>
<body>
<div id='app' style="width: 600px;height:400px"></div>
<button id="btn1">触发行为</button>
<button id="btn2">clear</button>
<button id="btn3">setOption</button>
<button id="btn4">dispose</button>
<script>
    var mCharts = echarts.init(document.getElementById("app"))
    var pieData = [
        {
            name: 'pass',
            value: 80
        },
        {
            name: 'fail',
            value: 10
        },
        {
            name: 'skip',
            value: 5
        },
        {
            name: 'error',
            value: 5
        }
    ]
    var option = {
        legend: {
            data: ['pass', 'fail', 'skip', 'error']
        },
        tooltip: {
            show: true
        },
        series: [
            {
                type: 'pie',
                data: pieData,
                label: {
                    show: true,
                    formatter: function (arg) {
                        console.log(arg)
                        return arg.data.name + '\n' + arg.percent + '%'
                    }
                },
                selectedMode: 'single',  // multiple 多选  single 单选
                selectedOffset: 30,// 偏移距离
                // radius: ['50%', '80%']
            }
        ]
    }
    mCharts.setOption(option)
    // 事件监听
    mCharts.on('click', function (arg) {
        console.log(arg)
    })
    mCharts.off('click') // 解绑click的事件
    // echarts事件变化
    mCharts.on('legendselectchanged', function (arg) {
        console.log('legendselectchanged', arg)
    })
    $('#btn1').click(function () {
        // 模拟用户的行为
        mCharts.dispatchAction({
            type: 'highlight',
            seriesIndex: 0, // 图表索引
            dataIndex: 1 // 数据的索引 图表中的哪一项
        })
        mCharts.dispatchAction({
            type: 'showTip',
            seriesIndex: 0,
            dataIndex: 0
        })
    })
    $('#btn2').click(function () {
        // 清空图表的实例
        mCharts.clear()
    })
    $('#btn3').click(function () {
        // 重新设置option
        mCharts.setOption(option)
    })
    $('#btn4').click(function () {
        // 销毁mCharts
        mCharts.dispose()
    })
</script>
</body>
</html>

相关文章
|
2月前
|
JavaScript 前端开发 API
深入浅出:Vue 3 Composition API 的魅力与实践
【2月更文挑战第13天】 本文将探索 Vue 3 的核心特性之一——Composition API。通过对比 Options API,本文旨在揭示 Composition API 如何提高代码的组织性和可复用性,并通过实际案例展示其在现代前端开发中的应用。不同于传统的技术文章摘要,我们将通过一个具体的开发场景,引领读者步入 Composition API 的世界,展现它如何优雅地解决复杂组件逻辑的管理问题,从而激发读者探索和运用 Vue 3 新特性的热情。
46 1
|
2月前
|
JavaScript 前端开发 API
深入浅出:Vue 3 Composition API 的魅力
【2月更文挑战第13天】 在前端开发的世界里,Vue.js 一直占据着重要的地位。随着 Vue 3 的推出,Composition API 成为了开发者热议的焦点。本文将从一个独特的视角探讨 Composition API 的核心优势,通过对比 Options API,解析其如何优化代码组织和提升项目的可维护性。我们将通过实际案例,深入理解 Composition API 的使用方法和最佳实践,帮助开发者更好地把握这一新工具,激发前端开发的无限可能。
|
2月前
|
JavaScript API
vue 3.0 所采用的 Composition Api 和 vue 2.0 使用的 Option Api 区别
vue 3.0 所采用的 Composition Api 和 vue 2.0 使用的 Option Api 区别
54 0
|
25天前
|
JavaScript 前端开发 测试技术
【vue实战项目】通用管理系统:api封装、404页
【vue实战项目】通用管理系统:api封装、404页
21 3
|
2月前
|
前端开发 JavaScript API
TS 中的类型验算,高级通用 API 实现
这篇文章介绍了一些常用的类型通用API封装,包括TS内置类型和关键字的使用,以及TS compiler内部实现的类型。文章截取了一些常用的类型定义和API示例,如Partial、Required、Readonly、NonNullable、Parameters等。还介绍了一些常用的TS关键字,如extends、infer、keyof、typeof、in等。此外,文章还提供了一些实现示例,如Optional API、GetOptional API和UnionToIntersection API。该文章会不断更新。
|
10天前
|
监控 Shell API
了解asyncio高级api索引
【6月更文挑战第27天】本文是`asyncio` 高级API概览:运行异步任务如`run()`, `create_task()`;等待机制如`gather()`, `wait_for()`, `shield()`;任务管理如`current_task()`, `all_tasks()`;队列和子进程功能;同步原语包括锁、事件和信号量。示例中涉及`sleep()`, `gather()`, `wait_for()`, 子进程创建及同步异常`TimeoutError`和`CancelledError`。查阅官方文档以获取详细信息和示例代码。
11 1
了解asyncio高级api索引
|
5天前
|
JavaScript 前端开发 定位技术
vue 使用 vue-jsonp 解决跨域请求问题(访问百度地图API)
vue 使用 vue-jsonp 解决跨域请求问题(访问百度地图API)
9 0
|
2月前
|
API
1天搞定SpringBoot+Vue全栈开发 (2)RESTful API与Swagger
1天搞定SpringBoot+Vue全栈开发 (2)RESTful API与Swagger
|
2月前
|
JavaScript 前端开发 API
组合API:掌握Vue的组合式API(Composition API)
【4月更文挑战第24天】Vue.js的组合式API是Vue 3中的新特性,旨在提供更灵活的组件逻辑组织方式。它允许开发者像React Hooks一样定义和复用逻辑单元——组合函数。通过组合函数,可以跨组件共享和管理状态,提升代码复用和维护性。本文介绍了如何开始使用组合式API,包括安装Vue CLI、引入API、使用组合函数以及组织和复用逻辑。掌握组合式API能增强开发复杂应用的能力,改善代码结构和可读性。
|
2月前
|
JavaScript 架构师 API
Vue 3.x全面升级指南:Composition API深度探索
Vue 3.x 的全面升级引入了 Composition API,这是对 Vue 2.x 传统 Options API 的一个重大改进,它提供了更加灵活和模块化的代码组织方式.
41 0