返回顶部
首页 > 资讯 > 前端开发 > 其他 >Vue3 echarts组件化及使用hook进行resize的方法是什么
  • 112
分享到

Vue3 echarts组件化及使用hook进行resize的方法是什么

Vue3hookecharts 2023-05-23 13:05:31 112人浏览 独家记忆
摘要

echarts组件化及使用hook进行resizehook 本质是一个函数,把setup函数中使用的 Composition api 进行了封装组件化echarts实例<template> <div ref="

    echarts组件化及使用hook进行resize

    hook 本质是一个函数,把setup函数中使用的 Composition api 进行了封装

    Vue3 echarts组件化及使用hook进行resize的方法是什么

    组件化echarts实例

    <template>
      <div ref="echart" :></div>
    </template>
    
    <script setup>
    import * as echarts from "echarts";
    import useResize from "@/hooks/useResize"; // hook 代码见下方
    
    const { proxy } = getCurrentInstance(); // 获取实例中的proxy
    
    let echart;
    let echartInstance;
    
    const props = defineProps({
      // 数据
      data: {
        type: Array,
        default: [
          { value: 40, name: "rose 1" },
          { value: 38, name: "rose 2" },
          { value: 32, name: "rose 3" },
        ],
      },
      // 高度
      height: {
        type: [Number, String],
        default: "300px",
      },
      // 宽度
      width: {
        type: [Number, String],
        default: "100%",
      },
    });
    
    const { data } = toRefs(props);
    
    const data1 = Reactive({
      option: {
        legend: {
          top: "bottom",
        },
        toolbox: {
          show: false,
          feature: {
            mark: { show: true },
            dataView: { show: true, readOnly: false },
            restore: { show: true },
            saveAsImage: { show: true },
          },
        },
        tooltip: {
          trigger: "item",
          fORMatter: "{b} : {c} ({d}%)",
        },
        series: [
          {
            name: "Nightingale Chart",
            type: "pie",
            radius: [10, 120],
            center: ["50%", "45%"],
            roseType: "area",
            itemStyle: {
              borderRadius: 8,
            },
            data: data.value,
          },
        ],
      },
    });
    
    const { option } = toRefs(data1);
    
    // 观察 data ,重新绘制
    watch(
      data,
      (newValue) => {
        option.value.series[0].data = newValue;
      },
      { deep: true }
    );
    watch(
      option,
      (newValue) => {
        echartInstance.setOption(newValue, true);
      },
      { deep: true }
    );
    
    onMounted(() => {
      echart = proxy.$refs.echart; // 获取的DOM根节点
      echartInstance = echarts.init(echart, "Macarons"); // 初始化 echart
      echartInstance.setOption(option.value, true); // 绘制
      // notMerge 可选。是否不跟之前设置的 option 进行合并。默认为 false。即表示合并。合并的规则,详见 组件合并模式。如果为 true,表示所有组件都会被删除,然后根据新 option 创建所有新组件。
      // setOption 见 https://echarts.apache.org/zh/api.html#echartsInstance.setOption
    });
    
    function resize() {
      echartInstance.resize();
    }
    
    // 暴露函数 (供hook调用)
    defineExpose({
      resize,
    });
    
    useResize();
    </script>

    hook (useResize)

    export default function () {
        let proxy
    
        onMounted(() => {
            proxy = getCurrentInstance(); // 获取实例中的proxy
            window.addEventListener('resize', resize)
        })
    
        onBeforeUnmount(() => {
            window.removeEventListener('resize', resize)
        })
    
        function resize() {
            proxy.exposed.resize()
        }
    }

    使用echarts和echarts自适应

    首先安装echarts,这个就不介绍了,直接说怎么使用.

    <!-- 创建一个div去显示echarts -->
    <div ref="main" ></div>
    import {ref, provide, inject, onMounted, reactive} from "Vue";
    import * as echarts from "echarts";
    const main = ref() // 使用ref创建虚拟DOM引用,使用时用main.value
    onMounted(
        () => {
            init()
        }
    )
    function init() {
        // 基于准备好的dom,初始化echarts实例
        var myChart = echarts.init(main.value);
        // 指定图表的配置项和数据
        var option = {
            
            tooltip: {},
            // color:['#779ffe','#a07dfe','#fc9b2e','#63f949','#fb6464','#fce481'],
            
            legend: {
                // data: ['国家类型','非国家类型','个人','法人','可公式','非公式']
            },
            xAxis: {
                type: 'cateGory',
                data: ['国家类型','非国家类型','个人','法人','可公式','非公式']
            },
            yAxis: {
                type: 'value',
                scale: true,
                max: 150,
                min: 0,
                splitNumber: 3,
            },
            series: [
                {
                    data: [
                        {
                            value: 120,
                            itemStyle: {
                                color: '#7fa6fe'
                            }
                        },
                        {
                            value: 90,
                            itemStyle: {
                                color: '#a17fff'
                            }
                        },
                        {
                            value: 40,
                            itemStyle: {
                                color: '#fda630'
                            }
                        },
                        {
                            value: 120,
                            itemStyle: {
                                color: '#93fc73'
                            }
                        },
                        {
                            value: 120,
                            itemStyle: {
                                color: '#fb6666'
                            }
                        },
                        {
                            value: 120,
                            itemStyle: {
                                color: '#fbe068'
                            }
                        }
                    ],
                    type: 'bar'
                }
            ]
        };
        // 使用刚指定的配置项和数据显示图表。
        myChart.setOption(option);
    }

    以上就是vue3 echarts组件化及使用hook进行resize的方法是什么的详细内容,更多请关注编程网其它相关文章!

    --结束END--

    本文标题: Vue3 echarts组件化及使用hook进行resize的方法是什么

    本文链接: https://www.lsjlt.com/news/216955.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • 小程序速报[No.90] | 小程序最新资讯,错过还要等2周
      ⭐本期内容速览:1、平台支付手续费调整通知2、关于canvas v2 保存图片的实现3、小程序变现锦囊:交易解决方案上线,新能力助力好生意4、交易类目限制订单金额及账期调整通知5、助力留资转化率,留资组件内测开启6、官方小程序上线,提升经营...
      99+
      2026-05-01
      头条 抖音 小程序 更新
    • 代码级质量技术之基本框架介绍
      一、背景代码级质量技术:顾名思义为了服务质量更好,涉及到代码层面的相关技术,特别要指出的是,代码级质量技术不单纯指代码召回技术,如静态代码扫描、单元测试等。研究代码级质量技术主要有以下几个方面的原因:1、随着精准测试等概念的兴起,对代码覆盖...
      99+
      2026-05-01
      代码级质量 框架
    • jquery清除同级div
      随着Web应用不断复杂,JavaScript框架变得越来越重要。其中最受欢迎的框架之一是jQuery,jQuery是一个流行的JavaScript库,它可以使处理文档元素、处理事件和创建特效更加容易。在这篇文章中,我们将学习如何使用jQue...
      99+
      2026-05-01
    • jquery 查询筛选
      JQuery是一款非常优秀的JavaScript库,提供了许多便捷的方法使得前端开发变得更加快捷高效。在JQuery中,查询筛选是其最常用的功能之一,本文将详细介绍JQuery查询筛选的相关部分。一、概述JQuery的查询筛选机制是其最重要...
      99+
      2026-05-01
    • jquery 图片无法显示
      在网页开发过程中,经常会用到图片来丰富页面内容,但有时会出现图片无法显示的情况,这个问题通常与文件路径或文件名有关。本文将介绍使用 jQuery 快速解决图片无法显示的问题。一、确认图片文件路径最常见的原因是图片文件路径错误或者图片文件不存...
      99+
      2026-05-01
    • jquery移除只读
      在使用HTML表单时,经常需要将一些输入框设置为只读状态,以防止用户对这些信息进行修改。但有时候需要在特定情况下,将这些输入框的只读属性移除,以便用户可以进行修改或编辑。这时候就需要使用jQuery来移除只读属性。jQuery是一种Java...
      99+
      2026-05-01
    • vue选择地址怎么做
      Vue是一种流行的JavaScript框架,用于构建交互式Web应用程序。在许多Web应用程序中,选择地址是常见的功能需求。本文将介绍如何使用Vue实现选择地址,包括如何使用第三方库和如何自定义Vue组件。一、使用第三方库一个常见的选择地址...
      99+
      2026-05-01
    • VUe双中括号属性如何使用
      Vue是一种流行的JavaScript框架,它使用双花括号(“{{”和“}}”)语法来实现属性与视图之间的数据绑定。VUe框架中的模板显示了被框架监控的变量的特定属性,当这些变量的值改变时,这些属性也跟随改变,从而在视图中自动更新相应的值。...
      99+
      2026-05-01
    • vue refs 方法参数
      随着前端技术的不断发展,Vue框架毫无疑问成为了前端框架中最受欢迎的一种。Vue组件的复杂性也越来越高,因此,Vue框架提供了许多API来使得开发更加灵活和高效。其中之一就是refs方法。refs 方法用于在Vue中访问组件的实例或元素。这...
      99+
      2026-05-01
    • vue.js函数求和
      Vue.js是一个流行的JavaScript框架,它使得前端开发变得更容易和更快速。在Vue.js中,我们可以通过函数来实现对数据的操作,并实现一些加减乘除等简单的数学计算。本文将介绍如何使用Vue.js实现一个函数求和功能。首先,我们需要...
      99+
      2026-05-01
    • yum 找不到 nodejs
      在使用 CentOS 或者 Ubuntu 等 Linux 系统时,我们不可避免地需要使用 yum 或 apt-get 等包管理工具来安装所需的软件包。而在使用 yum 安装软件包的过程中,有时会出现 “找不到软件包” 的错误提示。本文将聚焦...
      99+
      2026-05-01
    • jquery如何导入日历
      随着互联网的发展,我们的生活越来越数字化,各种应用也越来越多。在网站开发的过程中,日历组件常常被使用到。而jquery是当前最为流行和实用的JavaScript框架之一,它提供了丰富的API让我们能够快速地构建优秀的日历组件。本文将介绍如何...
      99+
      2026-05-01
    • vue中选择对象的第几个属性
      Vue是当今最流行的前端JavaScript框架之一。 它的数据绑定、组件化和单页面应用程序优化等特性具有很强的魅力,吸引了越来越多的开发人员加入到其生态系统中。 在Vue的开发中,我们经常需要选择对象的某个属性来进行操作。本篇文章将分享如...
      99+
      2026-05-01
    • jquery如何遍历属性
      jQuery是一款非常流行的JavaScript库,它提供了许多便利的方法来操作HTML文档和网页元素。其中一个很有用的方法是遍历属性。在这篇文章中,我们将介绍如何使用jQuery遍历属性。首先,让我们看一下jQuery提供的遍历属性的方法...
      99+
      2026-05-01
    • nodejs都有哪几个模块
      Node.js是一个基于Chrome V8引擎的JavaScript运行环境,它的出现使得JavaScript可以在服务器端运行。在Node.js中,有许多内置模块可以直接调用,也可以通过npm(Node.js Package Manage...
      99+
      2026-05-01
    • vue下拉选择器怎么搜索
      在Vue项目中,下拉选择器是一个常见的元素。有时候,用户需要通过搜索来快速找到所需的选项,这时候就需要一个支持搜索功能的下拉选择器。一个典型的下拉选择器由一个输入框和一个下拉列表组成。用户可以在输入框中输入内容,下拉列表中会展示匹配的选项,...
      99+
      2026-05-01
    • jquery如何实现定时器
      JQuery是一个非常流行的JavaScript库,它为我们提供了许多便利函数来操作DOM、事件处理、动画效果等等。其中,定时器也是JQuery中非常重要的一个功能,我们可以通过设置定时器来实现动态更新界面、轮播图等功能。接下来,本文将详细...
      99+
      2026-05-01
    • 电脑vue加载静态资源报错
      在使用Vue进行开发时,我们通常都会使用一些静态资源,例如图片、CSS文件、JavaScript文件等等。加载这些静态资源可以帮助我们更好地构建页面、增强用户体验。但有时候,我们会遇到电脑Vue加载静态资源报错的情况,这给开发者带来了一定的...
      99+
      2026-05-01
    • vue 禁止数据联动
      Vue 是一种流行的 JavaScript 框架,它的核心目的是使前端开发更加容易和快速。Vue 框架中最常用的概念之一是数据联动,它使得应用程序中的数据对于用户的行为变得非常敏感和动态。然而,有些时候,开发者可能会希望禁止数据联动,并且只...
      99+
      2026-05-01
    • jquery怎么清空数组元素
      在使用jQuery时,清空数组元素是一项很基础的任务。在本文中,我们将讨论如何使用jQuery清空数组元素。首先,让我们先了解什么是数组。在JavaScript中,数组是一组有序的数据值的集合。如果您想要存储一组具有相同类型的数据值,那么数...
      99+
      2026-05-01
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作