| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- <template>
- <div ref="chartRef" :style="{ height, width }"></div>
- </template>
- <script lang="ts">
- import { defineComponent, PropType, ref, Ref, reactive, watchEffect } from 'vue';
- import { useECharts } from '/@/hooks/web/useECharts';
- import { cloneDeep } from 'lodash-es';
- export default defineComponent({
- name: 'Radar',
- props: {
- chartData: {
- type: Array,
- default: () => [],
- },
- option: {
- type: Object,
- default: () => ({}),
- },
- width: {
- type: String as PropType<string>,
- default: '100%',
- },
- height: {
- type: String as PropType<string>,
- default: 'calc(100vh - 78px)',
- },
- },
- setup(props) {
- const chartRef = ref<HTMLDivElement | null>(null);
- const { setOptions } = useECharts(chartRef as Ref<HTMLDivElement>);
- const option = reactive({
- title: {
- text: '基础雷达图',
- },
- legend: {
- data: ['文综'],
- },
- radar: {
- indicator: [{ name: '历史' }, { name: '地理' }, { name: '生物' }, { name: '化学' }, { name: '物理' }, { name: '政治' }],
- },
- series: [
- {
- type: 'radar' as 'custom',
- data: [
- {
- value: [82, 70, 60, 55, 90, 66],
- name: '文综',
- },
- ],
- },
- ],
- });
- watchEffect(() => {
- props.chartData && initCharts();
- });
- function initCharts() {
- if (props.option) {
- Object.assign(option, cloneDeep(props.option));
- }
- //图例类型
- let typeArr = Array.from(new Set(props.chartData.map((item) => item.type)));
- //雷达数据
- let indicator = Array.from(
- new Set(
- props.chartData.map((item) => {
- let { name, max } = item;
- return { name, max };
- })
- )
- );
- let data = [];
- typeArr.forEach((type) => {
- let obj = { name: type };
- let chartArr = props.chartData.filter((item) => type === item.type);
- obj['value'] = chartArr.map((item) => item.value);
- //data数据
- data.push(obj);
- });
- option.radar.axisName = indicator;
- option.series[0]['data'] = data;
- setOptions(option);
- }
- return { chartRef };
- },
- });
- </script>
|