npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

dt-charts

v0.2.0

Published

基于echarts封装的vue组件,配置项与数据分离,简少代码量

Downloads

29

Readme

介绍

dt-charts是基于echarts封装的图表组件,使用它绘制图表可以大量减少你的时间和代码量。

使用dt-charts绘制图表时可以将数据从复杂的配置中抽离出来,让你更加专注与对数据的处理,你也可以将配置抽离出来单独管理,并设置在全局或者部分图表上

我们使用echarts时总是需要大量时间将接口返回的数据处理成echarts需要的数据,使用dt-charts只需要简单的配置即可帮你快速的处理数据。

dt-charts的使用方式和暴露的接口遵循大部分UI组件的规则,这可以帮助你快速上手。

安装

npm install dt-charts -s

快速上手

全量加载

main.js并注册

import Vue from "vue";
import App from "./App.vue";

import dtCharts from "dt-charts";

Vue.config.productionTip = false;

Vue.use(dtCharts [,option])
/**
	* option可选项如下
	* Vue.use(dtCharts, { 
	*   ⬇️注册时可以传入全局的配置(同echarts的配置项)
	*	  globalOpt: {},
	*   ⬇️json配置文件或注册过的主题名
  *   theme: {}
  * })
 	*/

new Vue({
  render: (h) => h(App),
}).$mount("#app");

按需加载

import { DtCharts, DtBar } from "d-charts"
export default {
  components: {
      DtCharts,
      DtBar
  },
}

绘制一个简单的图表

<template>
  <div class='home'>
    <dt-charts>
      <dt-bar :rows="rows"
              :columns="columns"></dt-bar>
    </dt-charts>
  </div>
</template>
<script>
    export default {
        name: 'Test',
        data(){
            return {
                // 模拟接口数据
                rows: [
                    { 'date': '01-01', 'PV': 1231, 'OP': 2342 },
                    { 'date': '01-02', 'PV': 1223, 'OP': 1342 },
                    { 'date': '01-03', 'PV': 2123, 'OP': 2312 },
                    { 'date': '01-04', 'PV': 4123, 'OP': 2242 },
                    { 'date': '01-05', 'PV': 3123, 'OP': 6342 },
                    { 'date': '01-06', 'PV': 7123, 'OP': 2142 }
                ],
                // columns用来定义将rows中的哪些字段绘制出来,以及设置seriesItem的其他配置
                columns: {
                    // 将rows中的date字段渲染成x轴且x轴为类目轴,如果想让date字段为y轴可以设置为yAxis
                    'date': 'xAxis',
                    // 将rows中的PV字段绘制出来,
                    'PV': {
                        // 这里写seriesItem里的所有一级配置
                        stack: '总数',
                        barWidth: 30
                    },
                    'OP': {
                        stack: '总数',
                        name: 'OPname'
                    }
                },
            }
        }
    }    
</script>

查看效果

下面我们再渲染一个折线图,并给图表加上主题

<template>
    <div class='home'>
      <dt-charts :theme="vintage">
        <dt-bar :rows="rows"
                :columns="columns"></dt-bar>
        <dt-line :rows="rows"
                 :columns="columnsLine"></dt-line>
      </dt-charts>
    </div>
<template>
<script>
    // 从echarts官网下载下来的主题文件
    import vintage from "@/theme/vintage.json";
    export default {
        name: 'Test',
        data(){
            return {
      					vintage: vintage,
                // 模拟接口数据
                rows: [
                    { 'date': '01-01', 'PV': 1231, 'OP': 2342, 'PV2': 1231, 'OP2': 2342 },
                    { 'date': '01-02', 'PV': 1223, 'OP': 1342, 'PV2': 1223, 'OP2': 1342 },
                    { 'date': '01-03', 'PV': 2123, 'OP': 2312, 'PV2': 2123, 'OP2': 2312 },
                    { 'date': '01-04', 'PV': 4123, 'OP': 2242, 'PV2': 4123, 'OP2': 2242 },
                    { 'date': '01-05', 'PV': 3123, 'OP': 6342, 'PV2': 3123, 'OP2': 6342 },
                    { 'date': '01-06', 'PV': 7123, 'OP': 2142, 'PV2': 7123, 'OP2': 2142 }
                ],
                columns: {
                    'date': 'xAxis',
                    'PV': {
                        stack: '总数',
                        barWidth: 30
                    },
                    'OP': {
                        stack: '总数',
                        name: 'OPname'
                    }
                },
                columnsLine: {
                    'PV2': {
                        stack: '总数',
                    },
                    'OP2': {
                        name: 'OPname2'
                    }
                },
            }
        }
    }    
</script>

查看效果

dt-charts

dt-charts是最重要的组件,所有图表都需要包裹在它里面,组件class默认样式宽度auto、高度400px

props

| 参数 | 说明 | 类型 | 默认值 | | ------------------ | ------------------------------------------------------------ | ------------------ | ------ | | initOptions | 初始化图表echarts.init时的配置项 | Object | {} | | setOptionOpts | echarts.setOption时的配置项 | Object | {} | | width | 图表宽度,默认空,优先级大于class中的样式 | String | '' | | height | 图表高度,默认空,优先级大于class中的样式 | String | '' | | dataEmpty | 空数据状态 | Boolean | false | | loading | 加载中状态 | Boolean | false | | theme | 主题: json配置文件或注册过的主题名 | Object || String | - | | defOpt | 默认配置(优先级大于全局配置globalOpt,小于ECHARTS_SETTINGS和子组件的itemOpt) | Object | {...} | | resizeable | 是否开启resize | Boolean | true | | resizeDelay | resize处理间隔,单位 ms | Number | 0 | | changeDelay | 子组件发生改变后处理option的间隔,单位 ms | Number | 0 | | ECHARTS_SETTINGS | echarts的其他配置(优先级大于默认配置defOpt),如果一些配置defOpt不能生效,建议使用ECHARTS_SETTINGS来覆盖,因为它的优先级最高 | | |

配置项优先级:

globalOpt 全局配置

< defOpt dt-charts的默认配置

< ( 子组件option.series中的配置: itemOpt < columns

​ 子组件option其他配置:子组件中的一些默认配置)

< ECHARTS_SETTINGS dt-charts的默认配置

ECHARTS_SETTINGS 其他配置列表如下(可选值与官网一致)

ECHARTS_SETTINGS = [
  'title', 'legend', 'grid', 'xAxis',
  'yAxis', 'polar', 'radiusAxis', 'angleAxis',
  'radar', 'dataZoom', 'visualMap', 'tooltip',
  'axisPointer', 'toolbox', 'brush', 'geo',
  'parallel', 'parallelAxis', 'singleAxis', 'timeline',
  'graphic', 'calendar', 'dataset', 'aria',
  'series', 'darkMode', 'color', 'backgroundColor',
  'textStyle', 'animation', 'animationThreshold', 'animationDuration',
  'animationEasing', 'animationDelay', 'animationDurationUpdate', 'animationEasingUpdate',
  'animationDelayUpdate', 'stateAnimation', 'blendMode', 'hoverLayerThreshold',
  'useUTC', 'options', 'media'
]

例:

<dt-charts :title="title"
           :legend="legend">
    <dt-bar :rows="rows"
            :columns="columns"></dt-bar>
</dt-charts>
export default {
    data(){
        return {
            title:{
                text: "销量统计",
                textStyle:{
                    color: '#c9c9c9'
                }
            },
            legend:{
                show: false
            }
        }
    }
}

如果你的配置项太多,推荐使用 v-bind="option" 的方式来绑定

<dt-charts v-bind="option">
    <dt-bar :rows="rows"
            :columns="columns"></dt-bar>
</dt-charts>
export default {
    data(){
        return {
            option:{
              title:{...},
              legend:{...},
              grid:{...},
              tooltip:{...}
            }
        }
    }
}

dt-echarts实例、方法

<dt-charts ref="myEcharts">
</dt-charts>
// 组件实例
// 获取echarts实例
this.$refs.myEcharts.echarts

// 组件方法
// 初始化echarts
this.$refs.myEcharts.init()
// 销毁echarts
this.$refs.myEcharts.clean()
// 获取设置的option
this.$refs.myEcharts.getOption
// 重新设置echarts尺寸
this.$refs.myEcharts.resize()

dt-echarts事件

<dt-charts @themeChange="themeChange"
           @setOption="setOption"
           @resize="resize">
</dt-charts>
themeChange(){
	console.log('主题发生改变')
},
setOption(option){
	console.log('设置setOption时触发,设置的option为:', option)
}
resize(){
	console.log('resizeable=true时resize被触发')
}

空数据、加载中

<!-- 空数据 -->
<dt-charts :dataEmpty="true"></dt-charts>
<!-- 加载中 -->
<dt-charts :loading="true"></dt-charts>

dt-bar、dt-line、dt-pictorialBar

  • dt-bar 柱状图
  • dt-line 折线图
  • dt-pictorialBar 象形柱状图

props

| 参数 | 说明 | 类型 | 默认值 | | --------- | ------------------ | ------- | ------ | | rows | 数据集合 | Array | [] | | columns | 配合rows展示数据 | Object | {} | | itemOpt | 默认的配置项 | Object | {} | | hidden | 是否将组件数据隐藏 | Boolean | false |

rows为数据集合

columns用来定义将rows中的哪些字段绘制出来,以及设置seriesItem的其他配置

itemOptseries[item]的默认配置,优先级最低,会被columns里的配置覆盖

hidden是否将组件数据隐藏,在子组件上使用 v-if或v-show,数据都不能正确的显示隐藏,如果你有这个需求请使用hidden

例:

<dt-charts :title="title"
           :legend="legend">
    <dt-bar :rows="rows"
            :columns="columns"></dt-bar>
</dt-charts>
export default {
    data(){
        return{
          title:{
                text: "销量统计",
                textStyle:{
                    color: '#c9c9c9'
                }
            },
            legend:{
                show: false
            },
            rows: [
                { 'date': '01-01', 'PV': 1231, 'OP': 2342, 'PV2': 1231, 'OP2': 2342 },
                { 'date': '01-02', 'PV': 1223, 'OP': 1342, 'PV2': 1223, 'OP2': 1342 },
                { 'date': '01-03', 'PV': 2123, 'OP': 2312, 'PV2': 2123, 'OP2': 2312 },
                { 'date': '01-04', 'PV': 4123, 'OP': 2242, 'PV2': 4123, 'OP2': 2242 },
                { 'date': '01-05', 'PV': 3123, 'OP': 6342, 'PV2': 3123, 'OP2': 6342 },
                { 'date': '01-06', 'PV': 7123, 'OP': 2142, 'PV2': 7123, 'OP2': 2142 }
            ],
            columns: {
                'date': 'xAxis',
                'PV': {
                    stack: '总数',
                    barWidth: 30
                },
                'OP': {
                    stack: '总数',
                    name: 'OPname'
                }
            },
        }
    }
}

columns中定义的字段都会渲染到页面上

示例中columns.date的值为xAxis,代表该图x轴为类目轴且rows中的date字段为类目轴数据,可选值:xAxisyAxis

'PV': { stack: '总数', barWidth: 30 }

代表渲染rows中的PV字段,并将PV的值合并到echartsoption.series[item]中,可选值与echarts官网一致

其中option.series[item].name是必须存在的,如PV字段没有name选项,我们会直接将PV作为name的值生成配置

如果某个字段不需要其他配置,也可以直接简写,如 OP:'OPname',OP是要渲染的字段,OPname是option.series[n].name

例如dt-bar组件columns中的配置,对应echarts配置项的series类型为bar的配置

上方代码生成后的完整option如下

// 你会发现生成后的配置多出了很多配置项,这是为了更好的体验,我们使不同的图携带了一些配置
{
    "title": {
        "show": true,
        "text": ""
    },
    "legend": {
        "show": false,
        "left": "10%",
        "right": "10%",
        "type": "scroll",
        "icon": "circle"
    },
    "tooltip": {
        "show": true,
        "trigger": "axis"
    },
    "grid": {
        "top": "15%",
        "left": "3%",
        "right": "5%",
        "bottom": "5%",
        "containLabel": true
    },
    "xAxis": [
        {
            "type": "category",
            "data": [
                "01-01",
                "01-02",
                "01-03",
                "01-04",
                "01-05",
                "01-06"
            ]
        }
    ],
    "yAxis": [
        {
            "type": "value"
        }
    ],
    "series": [
        {
            "data": [
                1231,
                1223,
                2123,
                4123,
                3123,
                7123
            ],
            "stack": "总数",
            "barWidth": 30,
            "name": "PV",
            "type": "bar"
        },
        {
            "data": [
                2342,
                1342,
                2312,
                2242,
                6342,
                2142
            ],
            "stack": "总数",
            "name": "OPname",
            "type": "bar"
        }
    ]
}

dt-pie饼图

props

| 参数 | 说明 | 类型 | 默认值 | | --------- | ------------------ | ------- | ------ | | rows | 数据集合 | Array | [] | | columns | 配合rows展示数据 | Object | {} | | itemOpt | 默认的配置项 | Object | {} | | hidden | 是否将组件数据隐藏 | Boolean | false |

rows为数据集合

columns用来定义将rows中的哪些字段绘制出来,以及设置seriesItem的其他配置

itemOptseries[item]的默认配置,优先级最低,会被columns里的配置覆盖

hidden是否将组件数据隐藏,在子组件上使用 v-if或v-show,数据都不能正确的显示隐藏,如果你有这个需求请使用hidden

和柱状图不同的是饼图有两个name,一个是系列的name(series[item].name),一个是数据的name(series[item].data[item].name)

所以要指定数据name的话需要在columns里定义dataName字段

例:

<dt-charts :theme="walden"
           :legend="legend">
  <dt-pie :rows="rows"
          :columns="columns"></dt-pie>
</dt-charts>
import walden from "@/theme/walden.json";
export default {
  data () {
    //这里存放数据
    return {
      walden: walden,
      columns: {
        // 内圈饼图
        count: {
          // 这个name代表series系列的name
          name: '销量',
          // dataName指定系列中数据的name,值对应rows中的字段
          dataName: 'display_str',
          // radius:饼图的半径
          radius: ['0%', '20%'],
          // 内圈隐藏label
          label: {
            show: false
          }
        },
        // 外圈饼图
        amount: {
          name: '金额',
          dataName: 'display_str',
          radius: ['40%', '60%'],
          // 外圈显示label
          label: {
            show: true
          }
        }
      },
      legend: {
        show: true,
        // legend.data可以是系列的name,也可以是数据的name
        data: ["上衣", "裤子", "裙子", "帽子", "鞋子", "短袖", "棉服"]
        // data: ["count", "金额"]
      },
      rows: [
        { "display_str": "上衣", "count": 19.0, "amount": 2953.07 },
        { "display_str": "裤子", "count": 60.0, "amount": 2836.69 },
        { "display_str": "裙子", "count": 67.0, "amount": 1524.0 },
        { "display_str": "帽子", "count": 385.0, "amount": 3874.53 },
        { "display_str": "鞋子", "count": 285.0, "amount": 1710.73 },
        { "display_str": "短袖", "count": 173.0, "amount": 961.05 },
        { "display_str": "棉服", "count": 96.0, "amount": 1342.1 }
      ],
    };
  },
}

上方代码生成的配置如下

{
    "series": [
        {
            "data": [
                {
                    "value": 19,
                    "name": "上衣"
                },
                {
                    "value": 60,
                    "name": "裤子"
                },
                {
                    "value": 67,
                    "name": "裙子"
                },
                {
                    "value": 385,
                    "name": "帽子"
                },
                {
                    "value": 285,
                    "name": "鞋子"
                },
                {
                    "value": 173,
                    "name": "短袖"
                },
                {
                    "value": 96,
                    "name": "棉服"
                }
            ],
            "name": "销量",
            "dataName": "display_str",
            "radius": [
                "0%",
                "20%"
            ],
            "label": {
                "show": false
            },
            "type": "pie"
        },
        {
            "data": [
                {
                    "value": 2953.07,
                    "name": "上衣"
                },
                {
                    "value": 2836.69,
                    "name": "裤子"
                },
                {
                    "value": 1524,
                    "name": "裙子"
                },
                {
                    "value": 3874.53,
                    "name": "帽子"
                },
                {
                    "value": 1710.73,
                    "name": "鞋子"
                },
                {
                    "value": 961.05,
                    "name": "短袖"
                },
                {
                    "value": 1342.1,
                    "name": "棉服"
                }
            ],
            "name": "金额",
            "radius": [
                "40%",
                "60%"
            ],
            "dataName": "display_str",
            "label": {
                "show": true
            },
            "type": "pie"
        }
    ],
    "tooltip": {
        "show": true,
        "trigger": "item"
    },
    "legend": {
        "show": true,
        "data": [
            "上衣",
            "裤子",
            "裙子",
            "帽子",
            "鞋子",
            "短袖",
            "棉服"
        ]
    }
}

dt-radar雷达图

props

| 参数 | 说明 | 类型 | 默认值 | | --------- | ------------------ | ------- | ------ | | rows | 数据集合 | Array | [] | | columns | 配合rows展示数据 | Object | {} | | itemOpt | 默认的配置项 | Object | {} | | hidden | 是否将组件数据隐藏 | Boolean | false |

rows为数据集合

columns用来定义将rows中的哪些字段绘制出来,以及设置seriesItem的其他配置

itemOptseries[item]的默认配置,优先级最低,会被columns里的配置覆盖

hidden是否将组件数据隐藏,在子组件上使用 v-if或v-show,数据都不能正确的显示隐藏,如果你有这个需求请使用hidden

雷达图需要指定两个name,一个是系列的name(series[item].name),一个是数据的name(series[item].data[item].name

和饼图不同的是数据的name不需要dataName指定,因为雷达图的series[item].data[item]中也需要配置

雷达图指示器的数据需要indicatorText字段来声明

<dt-charts>
  <dt-radar :rows="rows"
            :columns="columns"></dt-radar>
</dt-charts>
export default {
  data () {
    //这里存放数据
    return {
      rows: [
        { "display_str": "上衣", "count": 29.0, "amount": 53.07 },
        { "display_str": "裤子", "count": 30.0, "amount": 66.69 },
        { "display_str": "裙子", "count": 37.0, "amount": 54.0 },
        { "display_str": "帽子", "count": 35.0, "amount": 74.53 },
        { "display_str": "鞋子", "count": 25.0, "amount": 98.73 },
        { "display_str": "短袖", "count": 43.0, "amount": 61.05 },
        { "display_str": "棉服", "count": 46.0, "amount": 82.1 }
      ],
      columns: {
        count: {
          // series系列名称
          name: '数量',
          data: {
            // 数据名称
            name: 'data数量',
            // 其他配置
          },
          // 指示器文字
          indicatorText: 'display_str'
        },
        amount: {
          name: '单价',
          // data的值如果是String类型,则表示data.name
          data: 'data单价',
          indicatorText: 'display_str'
        }
      },
    };
  },
}

上方代码生成的配置如下

{
    "series": [
        {
            "name": "数量",
            "data": [
                {
                    "value": [
                        29,
                        30,
                        37,
                        35,
                        25,
                        43,
                        46
                    ],
                    "name": "data数量"
                }
            ],
            "indicatorText": "display_str",
            "type": "radar"
        },
        {
            "name": "单价",
            "data": [
                {
                    "value": [
                        53.07,
                        66.69,
                        54,
                        74.53,
                        98.73,
                        61.05,
                        82.1
                    ],
                    "name": "data单价"
                }
            ],
            "indicatorText": "display_str",
            "type": "radar"
        }
    ],
    "radar": [
        {
            "indicator": [
                {
                    "name": "上衣"
                },
                {
                    "name": "裤子"
                },
                {
                    "name": "裙子"
                },
                {
                    "name": "帽子"
                },
                {
                    "name": "鞋子"
                },
                {
                    "name": "短袖"
                },
                {
                    "name": "棉服"
                }
            ]
        }
    ],
    "tooltip": {
        "show": true
    },
    "legend": {
        "data": [
            "data数量",
            "data单价"
        ]
    }
}

下面我想绘制两个雷达,左边雷达设置成圆形,右边雷达的样式填充颜色,圆点设为方形

<dt-charts :radar="radar">
  <dt-radar :rows="rows"
            :columns="columns"></dt-radar>
  <dt-radar :itemOpt="itemOpt"
            :rows="rows2"
            :columns="columns"></dt-radar>
</dt-charts>
export default {
  data () {
    //这里存放数据
    return {
      rows: [
        { "display_str": "上衣", "count": 29.0, "amount": 53.07 },
        { "display_str": "裤子", "count": 30.0, "amount": 66.69 },
        { "display_str": "裙子", "count": 37.0, "amount": 54.0 },
        { "display_str": "帽子", "count": 35.0, "amount": 74.53 },
        { "display_str": "鞋子", "count": 25.0, "amount": 98.73 },
        { "display_str": "短袖", "count": 43.0, "amount": 61.05 },
        { "display_str": "棉服", "count": 46.0, "amount": 82.1 }
      ],
      rows2: [
        { "display_str": "上衣2", "count": 29.0, "amount": 53.07 },
        { "display_str": "裤子2", "count": 30.0, "amount": 66.69 },
        { "display_str": "裙子2", "count": 37.0, "amount": 54.0 },
        { "display_str": "帽子2", "count": 35.0, "amount": 74.53 },
        { "display_str": "鞋子2", "count": 25.0, "amount": 98.73 },
        { "display_str": "短袖2", "count": 43.0, "amount": 61.05 },
        { "display_str": "棉服2", "count": 46.0, "amount": 82.1 }
      ],
      // 设置系列中的默认配置项
      // 如果itemOpt和columns中设置了相同的配置,则columns优先级更高
      itemOpt: {
        // 此处配置级别与columns中的(其他配置2)位置一致
        areaStyle: {},
        // 改系列使用下标为1的雷达指示器
        radarIndex: 1,
        data: {
        	// series[item].data的配置项 与columns中的(其他配置1)位置一致
          symbol: 'rect',
        }
      },
      columns: {
        count: {
          name: '数量',
          data: {
            name: 'data数量',
            // 其他配置1
          },
          // 指示器文字
          indicatorText: 'display_str',
          // 其他配置2
        },
        amount: {
          name: '单价',
          data: 'data单价',
          indicatorText: 'display_str'
        }
      },
      // 设置雷达的属性
      radar: [{
        // 第一个雷达指示器为圆形
        shape: 'circle',
        // 中心点
        center: ['25%', '50%'],
      }, {
        // 第二个雷达的中心点
        center: ['75%', '50%']
      }]
    };
  },
}

上方代码生成的配置如下

{
    "series": [
        {
            "name": "数量",
            "data": [
                {
                    "value": [
                        29,
                        30,
                        37,
                        35,
                        25,
                        43,
                        46
                    ],
                    "name": "data数量"
                }
            ],
            "indicatorText": "display_str",
            "type": "radar"
        },
        {
            "name": "单价",
            "data": [
                {
                    "value": [
                        53.07,
                        66.69,
                        54,
                        74.53,
                        98.73,
                        61.05,
                        82.1
                    ],
                    "name": "data单价"
                }
            ],
            "indicatorText": "display_str",
            "type": "radar"
        },
        {
            "areaStyle": {},
            "radarIndex": 1,
            "data": [
                {
                    "symbol": "rect",
                    "value": [
                        29,
                        30,
                        37,
                        35,
                        25,
                        43,
                        46
                    ],
                    "name": "data数量"
                }
            ],
            "name": "数量",
            "indicatorText": "display_str",
            "type": "radar"
        },
        {
            "areaStyle": {},
            "radarIndex": 1,
            "data": [
                {
                    "symbol": "rect",
                    "value": [
                        53.07,
                        66.69,
                        54,
                        74.53,
                        98.73,
                        61.05,
                        82.1
                    ],
                    "name": "data单价"
                }
            ],
            "name": "单价",
            "indicatorText": "display_str",
            "type": "radar"
        }
    ],
    "radar": [
        {
            "indicator": [
                {
                    "name": "上衣"
                },
                {
                    "name": "裤子"
                },
                {
                    "name": "裙子"
                },
                {
                    "name": "帽子"
                },
                {
                    "name": "鞋子"
                },
                {
                    "name": "短袖"
                },
                {
                    "name": "棉服"
                }
            ],
            "shape": "circle",
            "center": [
                "25%",
                "50%"
            ]
        },
        {
            "indicator": [
                {
                    "name": "上衣2"
                },
                {
                    "name": "裤子2"
                },
                {
                    "name": "裙子2"
                },
                {
                    "name": "帽子2"
                },
                {
                    "name": "鞋子2"
                },
                {
                    "name": "短袖2"
                },
                {
                    "name": "棉服2"
                }
            ],
            "center": [
                "75%",
                "50%"
            ]
        }
    ],
    "tooltip": {
        "show": true
    },
    "legend": {
        "data": [
            "data数量",
            "data单价"
        ]
    }
}

其他图表

更多图表暂不支持,如果想绘制其他图表,你可以先把数据处理好然后绑定到dt-charts组件上

<dt-charts v-bind="option"
           ref="chart">
</dt-charts>
export default {
  data () {
    //这里存放数据
    return {
      option: {},
    };
  },
  //生命周期 - 挂载完成(可以访问DOM元素)
  mounted () {
    // 使用setTimeout模拟请求接口的延时
    setTimeout(() => {
      // 直接把官网雷达图示例的配置放上去
      this.option = {
        title: {
          text: 'Basic Radar Chart'
        },
        legend: {
          data: ['Allocated Budget', 'Actual Spending']
        },
        radar: {
          // shape: 'circle',
          indicator: [
            { name: 'Sales', max: 6500 },
            { name: 'Administration', max: 16000 },
            { name: 'Information Technology', max: 30000 },
            { name: 'Customer Support', max: 38000 },
            { name: 'Development', max: 52000 },
            { name: 'Marketing', max: 25000 }
          ]
        },
        series: [{
          name: 'Budget vs spending',
          type: 'radar',
          data: [
            {
              value: [4200, 3000, 20000, 35000, 50000, 18000],
              name: 'Allocated Budget'
            },
            {
              value: [5000, 14000, 28000, 26000, 42000, 21000],
              name: 'Actual Spending'
            }
          ]
        }]
      }
    }, 2000)
  }
}

Todo:

  • 更多图表持续更新中