|
@@ -12,14 +12,35 @@
|
|
|
|
|
|
<script>
|
|
<script>
|
|
export default {
|
|
export default {
|
|
|
|
+ props: {
|
|
|
|
+ courseArray: {
|
|
|
|
+ type: Array,
|
|
|
|
+ },
|
|
|
|
+ },
|
|
data() {
|
|
data() {
|
|
return {
|
|
return {
|
|
chartObj: null,
|
|
chartObj: null,
|
|
- option: {},
|
|
|
|
|
|
+ ooption: {
|
|
|
|
+ hours: [],
|
|
|
|
+ days: [],
|
|
|
|
+ data: [],
|
|
|
|
+ },
|
|
|
|
+ option: {
|
|
|
|
+ tooltip: {
|
|
|
|
+ position: "top",
|
|
|
|
+ formatter: function (params) {
|
|
|
|
+ // console.log(params);
|
|
|
|
+ return params.marker + params.name + " " + params.data[1]; //params.seriesName + '<br>' + params.
|
|
|
|
+ },
|
|
|
|
+ },
|
|
|
|
+ title: [],
|
|
|
|
+ singleAxis: [],
|
|
|
|
+ series: [],
|
|
|
|
+ },
|
|
};
|
|
};
|
|
},
|
|
},
|
|
methods: {
|
|
methods: {
|
|
- setChart() {
|
|
|
|
|
|
+ setChart(option) {
|
|
// 雷达图显示的标签
|
|
// 雷达图显示的标签
|
|
let newPromise = new Promise((resolve) => {
|
|
let newPromise = new Promise((resolve) => {
|
|
resolve();
|
|
resolve();
|
|
@@ -30,31 +51,34 @@ export default {
|
|
this.$el.querySelector("#charts_canvas")
|
|
this.$el.querySelector("#charts_canvas")
|
|
);
|
|
);
|
|
// 初始化雷达图
|
|
// 初始化雷达图
|
|
- const hours = [
|
|
|
|
- "语文",
|
|
|
|
- "数学",
|
|
|
|
- "英语",
|
|
|
|
- "科学",
|
|
|
|
- "体育",
|
|
|
|
- "音乐",
|
|
|
|
- "美术",
|
|
|
|
- "劳动",
|
|
|
|
- "其他",
|
|
|
|
- ];
|
|
|
|
|
|
+ const hours = option.hours;
|
|
|
|
+ // const hours = [
|
|
|
|
+ // "语文",
|
|
|
|
+ // "数学",
|
|
|
|
+ // "英语",
|
|
|
|
+ // "科学",
|
|
|
|
+ // "体育",
|
|
|
|
+ // "音乐",
|
|
|
|
+ // "美术",
|
|
|
|
+ // "劳动",
|
|
|
|
+ // "其他",
|
|
|
|
+ // ];
|
|
// prettier-ignore
|
|
// prettier-ignore
|
|
- const days = [
|
|
|
|
- '一年级', '二年级', '三年级',
|
|
|
|
- '四年级', '五年级', '六年级'
|
|
|
|
- ];
|
|
|
|
|
|
+ const days = option.days
|
|
|
|
+ // const days = [
|
|
|
|
+ // '一年级', '二年级', '三年级',
|
|
|
|
+ // '四年级', '五年级', '六年级'
|
|
|
|
+ // ];
|
|
// prettier-ignore
|
|
// prettier-ignore
|
|
- const data = [[0,0,3],[0,2,4],[0,3,8],[0,6,6],[0,8,4],[1,0,3],[1,2,4],[1,3,8],[1,6,6],[1,8,4],[2,1,13],[2,3,6],[2,4,3],[2,6,6],[2,8,4],[3,3,6],[3,4,3],[3,6,6],[3,7,4],[4,0,10],[4,2,13],[4,3,6],[4,4,3],[4,6,6],[4,7,3],[5,2,4],[5,3,6],[5,4,3],[5,5,10],[5,6,10],[5,7,3]];
|
|
|
|
|
|
+ const data = option.data
|
|
|
|
+ // const data = [[0,0,3],[0,2,4],[0,3,8],[0,6,6],[0,8,4],[1,0,3],[1,2,4],[1,3,8],[1,6,6],[1,8,4],[2,1,13],[2,3,6],[2,4,3],[2,6,6],[2,8,4],[3,3,6],[3,4,3],[3,6,6],[3,7,4],[4,0,10],[4,2,13],[4,3,6],[4,4,3],[4,6,6],[4,7,3],[5,2,4],[5,3,6],[5,4,3],[5,5,10],[5,6,10],[5,7,3]];
|
|
const title = [];
|
|
const title = [];
|
|
const singleAxis = [];
|
|
const singleAxis = [];
|
|
const series = [];
|
|
const series = [];
|
|
days.forEach(function (day, idx) {
|
|
days.forEach(function (day, idx) {
|
|
title.push({
|
|
title.push({
|
|
textBaseline: "middle",
|
|
textBaseline: "middle",
|
|
- top: ((idx + 0.5) * 90) / 6 + "%",
|
|
|
|
|
|
+ top: ((idx + 0.5) * 90) / days.length + "%",
|
|
text: day,
|
|
text: day,
|
|
textStyle: {
|
|
textStyle: {
|
|
fontSize: 12,
|
|
fontSize: 12,
|
|
@@ -65,8 +89,8 @@ export default {
|
|
type: "category",
|
|
type: "category",
|
|
boundaryGap: false,
|
|
boundaryGap: false,
|
|
data: hours,
|
|
data: hours,
|
|
- top: (idx * 90) / 6 + 5 + "%",
|
|
|
|
- height: 90 / 6 - 10 + "%",
|
|
|
|
|
|
+ top: (idx * 90) / days.length + 5 + "%",
|
|
|
|
+ height: 90 / days.length - 10 + "%",
|
|
});
|
|
});
|
|
series.push({
|
|
series.push({
|
|
singleAxisIndex: idx,
|
|
singleAxisIndex: idx,
|
|
@@ -74,35 +98,108 @@ export default {
|
|
type: "scatter",
|
|
type: "scatter",
|
|
data: [],
|
|
data: [],
|
|
symbolSize: function (dataItem) {
|
|
symbolSize: function (dataItem) {
|
|
- return dataItem[1] * 4;
|
|
|
|
|
|
+ return dataItem[1] * 3;
|
|
},
|
|
},
|
|
});
|
|
});
|
|
});
|
|
});
|
|
data.forEach(function (dataItem) {
|
|
data.forEach(function (dataItem) {
|
|
series[dataItem[0]].data.push([dataItem[1], dataItem[2]]);
|
|
series[dataItem[0]].data.push([dataItem[1], dataItem[2]]);
|
|
});
|
|
});
|
|
- this.option = {
|
|
|
|
- tooltip: {
|
|
|
|
- position: "top",
|
|
|
|
- },
|
|
|
|
- title: title,
|
|
|
|
- singleAxis: singleAxis,
|
|
|
|
- series: series,
|
|
|
|
- grid: {
|
|
|
|
- left: "3",
|
|
|
|
- right: "3",
|
|
|
|
- top: "3",
|
|
|
|
- bottom: 0,
|
|
|
|
- containLabel: true,
|
|
|
|
- },
|
|
|
|
- };
|
|
|
|
|
|
+ this.option.title = title;
|
|
|
|
+ this.option.singleAxis = singleAxis;
|
|
|
|
+ this.option.series = series;
|
|
this.chartObj = chartObj;
|
|
this.chartObj = chartObj;
|
|
this.chartObj.setOption(this.option);
|
|
this.chartObj.setOption(this.option);
|
|
});
|
|
});
|
|
},
|
|
},
|
|
|
|
+ setJson(array) {
|
|
|
|
+ if (array != undefined && array.length > 0) {
|
|
|
|
+ this.ooption = {
|
|
|
|
+ hours: [],
|
|
|
|
+ days: [],
|
|
|
|
+ data: [],
|
|
|
|
+ };
|
|
|
|
+ let _grade = [];
|
|
|
|
+ let _subject = [];
|
|
|
|
+ let data = [];
|
|
|
|
+
|
|
|
|
+ array.forEach(function (item, idx) {
|
|
|
|
+ _grade.push(item.name);
|
|
|
|
+ });
|
|
|
|
+
|
|
|
|
+ array[0].subject.forEach(function (item, idx) {
|
|
|
|
+ _subject.push(item.name);
|
|
|
|
+ });
|
|
|
|
+ array.forEach(function (item, idx) {
|
|
|
|
+ item.subject.forEach(function (item2, idx2) {
|
|
|
|
+ data.push([idx, idx2, item2.course]);
|
|
|
|
+ });
|
|
|
|
+ });
|
|
|
|
+ this.ooption.hours = _subject;
|
|
|
|
+ this.ooption.days = _grade;
|
|
|
|
+ this.ooption.data = data;
|
|
|
|
+ if (!this.chartObj) {
|
|
|
|
+ this.setChart(this.ooption);
|
|
|
|
+ } else {
|
|
|
|
+ const hours = this.ooption.hours;
|
|
|
|
+ // prettier-ignore
|
|
|
|
+ const days = this.ooption.days;
|
|
|
|
+ // prettier-ignore
|
|
|
|
+ const data = this.ooption.data;
|
|
|
|
+ const title = [];
|
|
|
|
+ const singleAxis = [];
|
|
|
|
+ const series = [];
|
|
|
|
+ days.forEach(function (day, idx) {
|
|
|
|
+ title.push({
|
|
|
|
+ textBaseline: "middle",
|
|
|
|
+ top: ((idx + 0.5) * 90) / days.length + "%",
|
|
|
|
+ text: day,
|
|
|
|
+ textStyle: {
|
|
|
|
+ fontSize: 12,
|
|
|
|
+ },
|
|
|
|
+ });
|
|
|
|
+ singleAxis.push({
|
|
|
|
+ left: 70,
|
|
|
|
+ type: "category",
|
|
|
|
+ boundaryGap: false,
|
|
|
|
+ data: hours,
|
|
|
|
+ top: (idx * 90) / days.length + 5 + "%",
|
|
|
|
+ height: 90 / days.length - 10 + "%",
|
|
|
|
+ });
|
|
|
|
+ series.push({
|
|
|
|
+ singleAxisIndex: idx,
|
|
|
|
+ coordinateSystem: "singleAxis",
|
|
|
|
+ type: "scatter",
|
|
|
|
+ data: [],
|
|
|
|
+ symbolSize: function (dataItem) {
|
|
|
|
+ return dataItem[1] * 3;
|
|
|
|
+ },
|
|
|
|
+ });
|
|
|
|
+ });
|
|
|
|
+ data.forEach(function (dataItem) {
|
|
|
|
+ series[dataItem[0]].data.push([dataItem[1], dataItem[2]]);
|
|
|
|
+ });
|
|
|
|
+
|
|
|
|
+ this.option.title = title;
|
|
|
|
+ this.option.singleAxis = singleAxis;
|
|
|
|
+ this.option.series = series;
|
|
|
|
+ this.chartObj.setOption(this.option);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ },
|
|
|
|
+ watch: {
|
|
|
|
+ courseArray: {
|
|
|
|
+ immediate: true,
|
|
|
|
+ deep: true,
|
|
|
|
+ handler(newValue, oldValue) {
|
|
|
|
+ this.setJson(newValue);
|
|
|
|
+ this.$forceUpdate();
|
|
|
|
+ },
|
|
|
|
+ },
|
|
},
|
|
},
|
|
mounted() {
|
|
mounted() {
|
|
- this.setChart(this.option);
|
|
|
|
|
|
+ this.setJson(this.courseArray);
|
|
var _this = this;
|
|
var _this = this;
|
|
window.addEventListener("resize", () => {
|
|
window.addEventListener("resize", () => {
|
|
if (_this.chartObj) {
|
|
if (_this.chartObj) {
|
|
@@ -110,9 +207,6 @@ export default {
|
|
}
|
|
}
|
|
});
|
|
});
|
|
},
|
|
},
|
|
- created() {
|
|
|
|
- this.setChart();
|
|
|
|
- },
|
|
|
|
};
|
|
};
|
|
</script>
|
|
</script>
|
|
|
|
|