|
@@ -40,29 +40,74 @@
|
|
|
<Echarts id="ww12" :option="waybillTrendObj" />
|
|
|
</div>
|
|
|
</div>
|
|
|
+ <div class="dashboard-content-top-left-item">
|
|
|
+ <div class="dashboard-content-top-left-item-top">
|
|
|
+ <div class="dashboard-content-top-left-item-top-title">
|
|
|
+ 始发站统计分析
|
|
|
+ </div>
|
|
|
+ <div class="dashboard-content-bottom-left-top-time" @click="showDatePicker(showTimeMsg.NodePeak)">
|
|
|
+ <el-icon color="#ffffff" size="18">
|
|
|
+ <Calendar />
|
|
|
+ </el-icon>
|
|
|
+ <el-icon color="#ffffff">
|
|
|
+ <CaretBottom />
|
|
|
+ </el-icon>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="dashboard-content-top-left-item-bottom">
|
|
|
+ <Echarts id="ww4" :option="nodePeakObj" />
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<!-- 地图 -->
|
|
|
<div class="dashboard-content-top-center">
|
|
|
- <div class="dashboard-content-top-center-top"></div>
|
|
|
+ <div class="dashboard-content-top-center-top">
|
|
|
+ <div class="dashboard-content-top-center-top-list">
|
|
|
+ <div class="dashboard-content-top-center-top-list-txt">重量</div>
|
|
|
+ <div class="dashboard-content-top-center-top-list-num">{{ weight }}</div>
|
|
|
+ </div>
|
|
|
+ <div class="dashboard-content-top-center-top-list">
|
|
|
+ <div class="dashboard-content-top-center-top-list-txt">航班数</div>
|
|
|
+ <div class="dashboard-content-top-center-top-list-num">{{ flightNums }}</div>
|
|
|
+ </div>
|
|
|
+ <div class="dashboard-content-top-center-top-list">
|
|
|
+ <div class="dashboard-content-top-center-top-list-txt">运单数</div>
|
|
|
+ <div class="dashboard-content-top-center-top-list-num">{{ stockNums }}</div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
<div class="dashboard-content-top-center-bottom">
|
|
|
- <div class="dashboard-content-top-center-bottom-box1">
|
|
|
- <div class="dashboard-content-top-center-bottom-box1-title">
|
|
|
- 航班数:{{ flightNums }}
|
|
|
+ <div class="dashboard-content-top-center-bottom-title">航班动态跟踪</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content">
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-head">
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-head-list">公司/航班号</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-head-list">航班状态</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-head-list">经停/到站</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-head-list">计划起飞</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-head-list">实际起飞</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-head-list">机型</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-head-list">类型</div>
|
|
|
</div>
|
|
|
- </div>
|
|
|
- <div class="dashboard-content-top-center-bottom-box2">
|
|
|
- <div class="dashboard-content-top-center-bottom-box2-title">
|
|
|
- 运单数:{{ stockNums }}
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-bottom">
|
|
|
+ <vue3-seamless-scroll :list="listData" :hover-stop="true" :hover="true" :step="0.3">
|
|
|
+ <div v-for="(item,index) in listData" :key="index" class="dashboard-content-top-center-bottom-content-bottom-list">
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-bottom-list-txt">{{ item.flightNo }}</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-bottom-list-txt">{{ item.flightState }}</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-bottom-list-txt">{{ item.airport }}</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-bottom-list-txt">{{ item.planTime }}</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-bottom-list-txt">{{ item.acTime }}</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-bottom-list-txt">{{ item.planeType }}</div>
|
|
|
+ <div class="dashboard-content-top-center-bottom-content-bottom-list-txt">{{ item.KHT }}</div>
|
|
|
+ </div>
|
|
|
+ </vue3-seamless-scroll>
|
|
|
</div>
|
|
|
</div>
|
|
|
- <EchartsMap :option="mapOptions" id="ww2" />
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="dashboard-content-top-right">
|
|
|
<div class="dashboard-content-top-right-item">
|
|
|
<div class="dashboard-content-top-right-item-top">
|
|
|
<div class="dashboard-content-top-right-item-top-title">
|
|
|
- 航班预警报警分析
|
|
|
+ 航司统计分析
|
|
|
</div>
|
|
|
<div class="dashboard-content-top-right-item-top-time" @click="showDatePicker(showTimeMsg.AirlineAbnormal)">
|
|
|
<el-icon color="#ffffff" size="18">
|
|
@@ -74,13 +119,13 @@
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="dashboard-content-top-right-item-bottom">
|
|
|
- <Echarts id="ww3" :option="airlineAbnormalBaggage.option" />
|
|
|
+ <Echarts id="a1" :option="airlineTrafficObj" />
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="dashboard-content-top-right-item">
|
|
|
<div class="dashboard-content-top-right-item-top">
|
|
|
<div class="dashboard-content-top-right-item-top-title">
|
|
|
- 航司运量统计
|
|
|
+ 航班动态统计
|
|
|
</div>
|
|
|
<div class="dashboard-content-top-right-item-top-time" @click="showDatePicker(showTimeMsg.AirlineTraffic)">
|
|
|
<el-icon color="#ffffff" size="18">
|
|
@@ -92,57 +137,27 @@
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="dashboard-content-top-left-item-bottom">
|
|
|
- <Echarts id="ww33" :option="airlineTrafficObj" />
|
|
|
+ <Echarts id="ww44" :option="airlineObj" />
|
|
|
</div>
|
|
|
</div>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div class="dashboard-content-bottom flex">
|
|
|
- <div class="dashboard-content-bottom-left">
|
|
|
- <div class="dashboard-content-bottom-left-top">
|
|
|
- <div class="dashboard-content-bottom-left-top-title">
|
|
|
- 节点峰值分布
|
|
|
- </div>
|
|
|
- <div class="dashboard-content-bottom-left-top-time" @click="showDatePicker(showTimeMsg.NodePeak)">
|
|
|
- <el-icon color="#ffffff" size="18">
|
|
|
- <Calendar />
|
|
|
- </el-icon>
|
|
|
- <el-icon color="#ffffff">
|
|
|
- <CaretBottom />
|
|
|
- </el-icon>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div class="dashboard-content-bottom-left-bottom">
|
|
|
- <Echarts id="ww4" :option="nodePeakObj" />
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div class="dashboard-content-bottom-center">
|
|
|
- <div class="dashboard-content-bottom-center-top">
|
|
|
- <div class="dashboard-content-bottom-center-top-title">
|
|
|
- 节点效率分析
|
|
|
- </div>
|
|
|
- <div class="dashboard-content-bottom-center-top-time" @click="showDatePicker()">
|
|
|
- <el-icon color="#ffffff" size="18">
|
|
|
- <Calendar />
|
|
|
- </el-icon>
|
|
|
- <el-icon color="#ffffff">
|
|
|
- <CaretBottom />
|
|
|
- </el-icon>
|
|
|
+ <div class="dashboard-content-top-right-item">
|
|
|
+ <div class="dashboard-content-top-right-item-top">
|
|
|
+ <div class="dashboard-content-top-right-item-top-title">
|
|
|
+ 拉货统计分析
|
|
|
+ </div>
|
|
|
+ <div class="dashboard-content-top-right-item-top-time" @click="showDatePicker(showTimeMsg.PickingStatistics)">
|
|
|
+ <el-icon color="#ffffff" size="18">
|
|
|
+ <Calendar />
|
|
|
+ </el-icon>
|
|
|
+ <el-icon color="#ffffff">
|
|
|
+ <CaretBottom />
|
|
|
+ </el-icon>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
- </div>
|
|
|
- <div class="dashboard-content-bottom-center-bottom">
|
|
|
- <Echarts id="ww5" :option="nodeEfficiency.option" />
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div class="dashboard-content-bottom-right">
|
|
|
- <div class="dashboard-content-bottom-right-top">
|
|
|
- <div class="dashboard-content-bottom-center-top-title">
|
|
|
- 航班动态统计
|
|
|
+ <div class="dashboard-content-top-left-item-bottom">
|
|
|
+ <Echarts id="ww45" :option="pickingObj" />
|
|
|
</div>
|
|
|
</div>
|
|
|
- <div class="dashboard-content-bottom-right-bottom">
|
|
|
- <Echarts id="ww6" :option="airStutas.option" />
|
|
|
- </div>
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
@@ -161,77 +176,31 @@
|
|
|
|
|
|
<script setup lang="ts">
|
|
|
import { ref, onMounted } from "vue";
|
|
|
+import { Vue3SeamlessScroll } from "vue3-seamless-scroll";
|
|
|
import Echarts from "@/components/Echarts/commonChartsBar.vue";
|
|
|
-import EchartsMap from "@/components/Echarts/commonChartsChinaMap.vue";
|
|
|
import ComHead from "./components/comHead.vue";
|
|
|
import { Calendar, CaretBottom } from "@element-plus/icons-vue";
|
|
|
import Dialog from "@/components/dialog/index.vue";
|
|
|
import { usePublic, showTimeMsg } from "./hooks/usePublic";
|
|
|
-import { parseTime } from "@/utils/validate";
|
|
|
+import { parseTime, isValue } from "@/utils/validate";
|
|
|
import * as _ from "lodash";
|
|
|
-const {
|
|
|
- optionLeft,
|
|
|
- airlineAbnormalBaggage,
|
|
|
- airCompaneBaggage,
|
|
|
- airStutas,
|
|
|
- nodeEfficiency,
|
|
|
- hourPeak,
|
|
|
- getPublicData,
|
|
|
- getMapData,
|
|
|
-} = usePublic();
|
|
|
+const { optionLeft, airCompaneBaggage, airStutas, getPublicData } = usePublic();
|
|
|
const timePickerName = ref<number>(0);
|
|
|
const flag = ref<boolean>(false);
|
|
|
const hourlyPeakObj = ref<any>({});
|
|
|
const waybillTrendObj = ref<any>({});
|
|
|
const nodePeakObj = ref<any>({});
|
|
|
const airlineTrafficObj = ref<any>({});
|
|
|
+const airlineObj = ref<any>({});
|
|
|
+const pickingObj = ref<any>({});
|
|
|
const flightNums = ref<number>(0);
|
|
|
const stockNums = ref<number>(0);
|
|
|
-const mapOptions = ref<any>({
|
|
|
- tooltip: {
|
|
|
- trigger: "item",
|
|
|
- formatter: function (params, ticket, callback) {
|
|
|
- if (params.seriesType == "effectScatter") {
|
|
|
- return "线路:" + params.data.name + "" + params.data.value[2];
|
|
|
- } else if (params.seriesType == "lines") {
|
|
|
- return (
|
|
|
- params.data.fromName +
|
|
|
- ">" +
|
|
|
- params.data.toName +
|
|
|
- "<br />" +
|
|
|
- params.data.value
|
|
|
- );
|
|
|
- } else {
|
|
|
- return params.name;
|
|
|
- }
|
|
|
- },
|
|
|
- },
|
|
|
- geo: {
|
|
|
- map: "china",
|
|
|
- label: {
|
|
|
- emphasis: {
|
|
|
- show: true,
|
|
|
- color: "#fff",
|
|
|
- },
|
|
|
- },
|
|
|
- roam: true,
|
|
|
- itemStyle: {
|
|
|
- normal: {
|
|
|
- areaColor: "#154186",
|
|
|
- borderColor: "#255caf",
|
|
|
- },
|
|
|
- emphasis: {
|
|
|
- areaColor: "#255caf",
|
|
|
- },
|
|
|
- },
|
|
|
- },
|
|
|
- series: [],
|
|
|
-});
|
|
|
+const weight = ref<number>(0);
|
|
|
const form = ref({
|
|
|
startDate: parseTime(Date.now() - 24 * 60 * 60 * 1000 * 7, "{y}-{m}-{d}"),
|
|
|
endDate: parseTime(Date.now(), "{y}-{m}-{d}"),
|
|
|
});
|
|
|
-
|
|
|
+const listData = ref<any>([]);
|
|
|
const disabledStartDate = (time: Date) => {
|
|
|
const timer: any = form.value.endDate;
|
|
|
const data = new Date(timer);
|
|
@@ -264,6 +233,9 @@ const submitForm = () => {
|
|
|
case showTimeMsg.AirlineAbnormal:
|
|
|
airlineAbnormalFunc();
|
|
|
break;
|
|
|
+ case showTimeMsg.PickingStatistics:
|
|
|
+ pickingFuncs();
|
|
|
+ break;
|
|
|
default:
|
|
|
break;
|
|
|
}
|
|
@@ -309,106 +281,116 @@ const pubFunc = (listValues, target) => {
|
|
|
//获取小时峰值分布
|
|
|
const hourlyPeakFunc = async () => {
|
|
|
const listValues = (await getPublicData(DATACONTENT_ID.jscHourlyPeakId, [
|
|
|
- { fd1: form.value.startDate },
|
|
|
- { fd2: form.value.endDate },
|
|
|
+ { fd1: form.value.startDate, fd2: form.value.endDate },
|
|
|
])) as any;
|
|
|
- hourlyPeakObj.value = pubFunc(listValues, optionLeft);
|
|
|
+ if (listValues && isValue(listValues)) {
|
|
|
+ hourlyPeakObj.value = pubFunc(listValues, optionLeft);
|
|
|
+ }
|
|
|
};
|
|
|
|
|
|
//运单趋势分析
|
|
|
const waybillTrendFunc = async () => {
|
|
|
const listValues = (await getPublicData(DATACONTENT_ID.jscWaybillTrendId, [
|
|
|
- { fd1: form.value.startDate },
|
|
|
- { fd2: form.value.endDate },
|
|
|
+ { fd1: form.value.startDate, fd2: form.value.endDate },
|
|
|
])) as any;
|
|
|
- waybillTrendObj.value = pubFunc(listValues, optionLeft);
|
|
|
+ if (listValues && isValue(listValues)) {
|
|
|
+ waybillTrendObj.value = pubFunc(listValues, optionLeft);
|
|
|
+ }
|
|
|
};
|
|
|
|
|
|
-//节点峰值
|
|
|
+//始发站/目的站统计分析
|
|
|
const nodePeakFunc = async () => {
|
|
|
- const listValues = (await getPublicData(DATACONTENT_ID.jscNodePeakId, [
|
|
|
- { fd1: form.value.startDate },
|
|
|
- { fd2: form.value.endDate },
|
|
|
+ const listValues = (await getPublicData(DATACONTENT_ID.jscAirlineAbnormalId, [
|
|
|
+ { fd1: form.value.startDate, fd2: form.value.endDate, fttp: "国内出港" },
|
|
|
])) as any;
|
|
|
- const newObj = _.cloneDeep(hourPeak.option);
|
|
|
- const arr = sortClass(listValues);
|
|
|
- const [title, series, singleAxis] = [<any>[], <any>[], <any>[]];
|
|
|
- arr.forEach((item, index) => {
|
|
|
- const msg: any = [];
|
|
|
- const datas: any = [];
|
|
|
- item.map((p, i) => {
|
|
|
- msg.push(p.stockNum);
|
|
|
- datas.push(i + 1);
|
|
|
- });
|
|
|
- title.push({
|
|
|
- top: ((index + 0.5) * 100) / 4 - 3 + "%",
|
|
|
- text: item[0].jobName,
|
|
|
- textStyle: {
|
|
|
- fontSize: 12,
|
|
|
- fontWeight: "normal",
|
|
|
- color: "#698dc3",
|
|
|
- },
|
|
|
+ if (listValues && isValue(listValues)) {
|
|
|
+ const newObj = _.cloneDeep(airCompaneBaggage.option.baseOption);
|
|
|
+ listValues.forEach((item) => {
|
|
|
+ item.jobTime = item["airport"];
|
|
|
});
|
|
|
- series.push({
|
|
|
- singleAxisIndex: index,
|
|
|
- coordinateSystem: "singleAxis",
|
|
|
- type: "scatter",
|
|
|
- data: msg,
|
|
|
- });
|
|
|
- singleAxis.push({
|
|
|
- type: "category",
|
|
|
- data: datas,
|
|
|
- top: ((index + 0.5) * 100) / 4 - 3 + "%",
|
|
|
- height: 100 / 4 - 5 + "%",
|
|
|
- left: "12%",
|
|
|
- right: "1%",
|
|
|
- axisTick: {
|
|
|
- show: false,
|
|
|
- },
|
|
|
- splitLine: {
|
|
|
- show: false,
|
|
|
- },
|
|
|
- });
|
|
|
- });
|
|
|
- newObj.series = series;
|
|
|
- newObj.singleAxis = singleAxis;
|
|
|
- newObj.title = title;
|
|
|
- nodePeakObj.value = newObj;
|
|
|
+ nodePeakObj.value = pubFunc(listValues, newObj);
|
|
|
+ }
|
|
|
};
|
|
|
|
|
|
//航班数&运单数
|
|
|
const numbersFunc = async () => {
|
|
|
const listValues = (await getPublicData(DATACONTENT_ID.jscNumbersId, [
|
|
|
- { fd1: form.value.startDate },
|
|
|
- { fd2: form.value.endDate },
|
|
|
+ { fd1: form.value.startDate, fd2: form.value.endDate },
|
|
|
])) as any;
|
|
|
- const { flightNum, stockNum } = listValues[0];
|
|
|
- flightNums.value = flightNum;
|
|
|
- stockNums.value = stockNum;
|
|
|
+ if (listValues && isValue(listValues)) {
|
|
|
+ const { flightNum, stockNum, weight } = listValues[0];
|
|
|
+ flightNums.value = flightNum;
|
|
|
+ stockNums.value = stockNum;
|
|
|
+ weight.value = weight;
|
|
|
+ }
|
|
|
};
|
|
|
|
|
|
//航司运量
|
|
|
const airlineTrafficFunc = async () => {
|
|
|
const listValues = (await getPublicData(DATACONTENT_ID.jscAirlineTrafficId, [
|
|
|
- { fd1: form.value.startDate },
|
|
|
- { fd2: form.value.endDate },
|
|
|
+ { fd1: form.value.startDate, fd2: form.value.endDate },
|
|
|
])) as any;
|
|
|
- listValues.forEach((item) => {
|
|
|
- item.jobTime = item["IACACode"];
|
|
|
- });
|
|
|
- airlineTrafficObj.value = pubFunc(
|
|
|
- listValues,
|
|
|
- airCompaneBaggage.option.baseOption
|
|
|
- );
|
|
|
+ if (listValues && isValue(listValues)) {
|
|
|
+ listValues.forEach((item) => {
|
|
|
+ item.jobTime = item["IACACode"];
|
|
|
+ });
|
|
|
+ airlineTrafficObj.value = pubFunc(
|
|
|
+ listValues,
|
|
|
+ airCompaneBaggage.option.baseOption
|
|
|
+ );
|
|
|
+ }
|
|
|
};
|
|
|
|
|
|
-//航班预警报警分析
|
|
|
+//航班表格
|
|
|
const airlineAbnormalFunc = async () => {
|
|
|
- const listValues = (await getPublicData(DATACONTENT_ID.jscAirlineAbnormalId, [
|
|
|
- { fd1: form.value.startDate },
|
|
|
- { fd2: form.value.endDate },
|
|
|
+ const listValues = (await getPublicData(DATACONTENT_ID.jscFlightDynamicsId, [
|
|
|
+ {
|
|
|
+ fd1: form.value.startDate,
|
|
|
+ fd2: form.value.endDate,
|
|
|
+ fttp: "国内出港",
|
|
|
+ },
|
|
|
])) as any;
|
|
|
- // console.log(listValues);
|
|
|
+ if (listValues && isValue(listValues)) {
|
|
|
+ listData.value = listValues;
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+//航班动态统计
|
|
|
+const airlineFunc = async () => {
|
|
|
+ const listValues = (await getPublicData(DATACONTENT_ID.jscAirlineId, [
|
|
|
+ {
|
|
|
+ fd1: form.value.startDate,
|
|
|
+ fd2: form.value.endDate,
|
|
|
+ },
|
|
|
+ ])) as any;
|
|
|
+ if (listValues && isValue(listValues)) {
|
|
|
+ const newObj = _.cloneDeep(airCompaneBaggage.option.baseOption);
|
|
|
+ listValues.forEach((item) => {
|
|
|
+ item.jobTime = item["nodeCode"];
|
|
|
+ item.stockNum = item["flightNum"];
|
|
|
+ item.weight = item["stockNum"];
|
|
|
+ });
|
|
|
+ airlineObj.value = pubFunc(listValues, newObj);
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+//拉货统计
|
|
|
+const pickingFuncs = async () => {
|
|
|
+ const listValues = (await getPublicData(DATACONTENT_ID.jscGgPullId, [
|
|
|
+ {
|
|
|
+ fd1: form.value.startDate,
|
|
|
+ fd2: form.value.endDate,
|
|
|
+ },
|
|
|
+ ])) as any;
|
|
|
+ if (listValues && isValue(listValues)) {
|
|
|
+ const newObj = _.cloneDeep(airCompaneBaggage.option.baseOption);
|
|
|
+ listValues.forEach((item) => {
|
|
|
+ item.jobTime = item["flightDate"];
|
|
|
+ item.stockNum = item["flightNum"];
|
|
|
+ item.weight = item["stockNum"];
|
|
|
+ });
|
|
|
+ pickingObj.value = pubFunc(listValues, newObj);
|
|
|
+ }
|
|
|
};
|
|
|
|
|
|
onMounted(() => {
|
|
@@ -418,31 +400,8 @@ onMounted(() => {
|
|
|
numbersFunc();
|
|
|
airlineTrafficFunc();
|
|
|
airlineAbnormalFunc();
|
|
|
- setTimeout(() => {
|
|
|
- var BJData = [
|
|
|
- [{ name: "北京" }, { name: "深圳", value: 95 }],
|
|
|
- [{ name: "成都" }, { name: "深圳", value: 95 }],
|
|
|
- [{ name: "重庆" }, { name: "深圳", value: 95 }],
|
|
|
- [{ name: "西安" }, { name: "深圳", value: 95 }],
|
|
|
- [{ name: "太原" }, { name: "深圳", value: 95 }],
|
|
|
- ];
|
|
|
- var GZData = [
|
|
|
- [{ name: "深圳" }, { name: "福州", value: 95 }],
|
|
|
- [{ name: "深圳" }, { name: "太原", value: 90 }],
|
|
|
- [{ name: "深圳" }, { name: "长春", value: 80 }],
|
|
|
- [{ name: "深圳" }, { name: "重庆", value: 70 }],
|
|
|
- [{ name: "深圳" }, { name: "西安", value: 60 }],
|
|
|
- [{ name: "深圳" }, { name: "成都", value: 50 }],
|
|
|
- [{ name: "深圳" }, { name: "常州", value: 40 }],
|
|
|
- [{ name: "深圳" }, { name: "北京", value: 30 }],
|
|
|
- [{ name: "深圳" }, { name: "北海", value: 20 }],
|
|
|
- [{ name: "深圳" }, { name: "海口", value: 10 }],
|
|
|
- ];
|
|
|
- mapOptions.value.series = getMapData([
|
|
|
- ["北京", BJData],
|
|
|
- ["深圳", GZData],
|
|
|
- ]);
|
|
|
- }, 0);
|
|
|
+ airlineFunc();
|
|
|
+ pickingFuncs();
|
|
|
});
|
|
|
</script>
|
|
|
|