prod
lily.zhang 4 years ago
parent 59cc2a5d36
commit d9ed2349bf

@ -0,0 +1,22 @@
/*
* @Author: your name
* @Date: 2021-11-11 15:12:31
* @LastEditTime: 2021-11-11 16:42:55
* @LastEditors: Please set LastEditors
* @Description: 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
* @FilePath: /data-show/src/api/ModelComparison/index.js
*/
import httpService from "@/request"
// 事件-事件分类
export function getEventsSeriesNameC(params) {
let obj = Object.assign({action: 'getEventsSeriesNameC',sType: 'HotEvent0528'}, params)
return httpService({
url: `/api/v6.ashx`,
method: 'post',
data: obj,
headers: {
'content-type': 'application/x-www-form-urlencoded'
}
})
}

@ -1,7 +1,7 @@
/* /*
* @Author: your name * @Author: your name
* @Date: 2021-10-21 11:36:36 * @Date: 2021-10-21 11:36:36
* @LastEditTime: 2021-10-29 21:30:46 * @LastEditTime: 2021-11-11 15:03:09
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/utils/gol/bubbleWord.js * @FilePath: /data-show/src/utils/gol/bubbleWord.js
@ -113,7 +113,6 @@ export default function createWordCloud(obj) {
extraCssText: "box-shadow: 0px 0px 10px 0px #3373CC;", extraCssText: "box-shadow: 0px 0px 10px 0px #3373CC;",
formatter: function (param) { formatter: function (param) {
let data = param.data; let data = param.data;
console.log(data)
return `<span>${data.name}</span><br><span>${data.value}</span>` return `<span>${data.name}</span><br><span>${data.value}</span>`
} }
}, },

@ -1,13 +1,13 @@
<!-- <!--
* @Author: your name * @Author: your name
* @Date: 2021-10-15 15:34:26 * @Date: 2021-10-15 15:34:26
* @LastEditTime: 2021-11-11 10:45:28 * @LastEditTime: 2021-11-11 16:43:10
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/BrandComparison/keyMediaCommunicationComparison/index.vue * @FilePath: /data-show/src/views/BrandComparison/keyMediaCommunicationComparison/index.vue
--> -->
<template> <template>
<div class="kmcc-outter"> <div class="kmcc-outter" v-loading="load">
<v-label-div title="重点媒体传播对比"> </v-label-div> <v-label-div title="重点媒体传播对比"> </v-label-div>
<div class="kmcc-inner"> <div class="kmcc-inner">
<v-echarts :opt="opt"></v-echarts> <v-echarts :opt="opt"></v-echarts>
@ -22,6 +22,7 @@ export default {
name: "kmcc-outter", name: "kmcc-outter",
data() { data() {
return { return {
load: false,
form: { form: {
token: "", token: "",
sBrand: "", sBrand: "",
@ -46,7 +47,6 @@ export default {
getData() { getData() {
let obj = Object.assign({}, this.getCtime2, this.form); let obj = Object.assign({}, this.getCtime2, this.form);
getSourceCount0528C(obj).then((res) => { getSourceCount0528C(obj).then((res) => {
let data = res.data; let data = res.data;
this.opt = createOpt(data); this.opt = createOpt(data);
}) })

@ -1,7 +1,7 @@
/* /*
* @Author: your name * @Author: your name
* @Date: 2021-10-09 11:01:19 * @Date: 2021-10-09 11:01:19
* @LastEditTime: 2021-10-15 15:51:52 * @LastEditTime: 2021-11-11 16:24:21
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/Index/spreadTheSound/opt.js * @FilePath: /data-show/src/views/Index/spreadTheSound/opt.js
@ -51,9 +51,9 @@ export default function createOpt(dataList = []) {
let info = createData(dataList); let info = createData(dataList);
return { return {
grid: { grid: {
left: 16, left: 10,
right: 16, right: '5%',
bottom: 16, bottom: 10,
top: 56, top: 56,
containLabel: true containLabel: true
}, },

@ -1,7 +1,7 @@
<!-- <!--
* @Author: your name * @Author: your name
* @Date: 2021-11-05 13:49:05 * @Date: 2021-11-05 13:49:05
* @LastEditTime: 2021-11-11 14:41:37 * @LastEditTime: 2021-11-11 14:55:29
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/BrandComparison/BrandComparison.vue * @FilePath: /data-show/src/views/BrandComparison/BrandComparison.vue
@ -106,7 +106,7 @@ export default {
keyMediaCommunicationComparison, // keyMediaCommunicationComparison, //
brandCommunicationTOPMedia, // TOP brandCommunicationTOPMedia, // TOP
overallWordCloudComparison, // overallWordCloudComparison, //
brandEventComparison, // brandEventComparison, //
comparisonOfWeiboInformation, // comparisonOfWeiboInformation, //
comparisonOfTheNumberOfWeiboInteractions, // comparisonOfTheNumberOfWeiboInteractions, //
weiboBigVComparison, // V weiboBigVComparison, // V

@ -1,49 +1,44 @@
<!-- <!--
* @Author: your name * @Author: your name
* @Date: 2021-10-15 17:33:28 * @Date: 2021-10-15 17:33:28
* @LastEditTime: 2021-10-15 18:25:51 * @LastEditTime: 2021-11-11 15:59:58
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/BrandComparison/brandEventComparison/index.vue * @FilePath: /data-show/src/views/BrandComparison/brandEventComparison/index.vue
--> -->
<template> <template>
<div class="bec-outter"> <div class="bec-outter">
<v-label-div title="品牌事件对比"> </v-label-div> <v-label-div title="车型事件对比"> </v-label-div>
<div class="bec-inner"> <div class="bec-inner">
<v-label-div title="渠道声量对比" :showLine="false" :eStyle="{ 'border-style': 'none' }">
</v-label-div>
<div class="bec-inner-1">
<v-echarts :opt="opt1"></v-echarts> <v-echarts :opt="opt1"></v-echarts>
</div> </div>
<v-label-div </div>
title="事件上榜车型" <v-label-div title="事件分类" :showLine="false" :eStyle="{ 'border-style': 'none' }">
:showLine="false"
:eStyle="{ 'border-style': 'none' }"
>
</v-label-div> </v-label-div>
<div class="bec-one"> <div class="bec-one">
<div class="bec-one-item" v-for="(item, index) in list" :key="index"> <v-echarts :opt="opt2"></v-echarts>
<span class="s1" :style="{ color: colors[index] }">{{
item.name
}}</span>
<div class="d1">
<v-echarts :opt="item.drawOpt"></v-echarts>
</div>
</div>
</div> </div>
</div> </div>
</template> </template>
<script> <script>
import { getSourcetypeC } from "@/api/BrandComparison/HotEvent.js"; import { getSourcetypeC } from "@/api/BrandComparison/HotEvent.js";
import { getContrastCount0528C } from "@/api/BrandComparison/HotEvent.js"; import { getEventsSourceType0528 } from "@/api/ModelComparison";
import { createSideSingleColumn } from "@/utils/gol/sideSingleColumn";
import createOpt from "./opt"; import createOpt from "./opt";
export default { export default {
name: "brandEventComparison", name: "brandEventComparison",
data() { data() {
return { return {
opt1: createOpt(), opt1: {},
opt2: {},
form: { form: {
token: "", token: "",
sBrand: "", sBrand: "",
sSeriesName: "",
iContrastType: 2,
}, },
colors: [ colors: [
"#3373CC", "#3373CC",
@ -53,56 +48,7 @@ export default {
"#CC7733", "#CC7733",
"#CC5B41", "#CC5B41",
], ],
list: [
{
name: "奥迪",
drawOpt: createSideSingleColumn(
["A4", "A3", "Q5", "A7", "A6"],
[400, 500, 600, 800, 1000],
"#3373CC"
),
},
{
name: "宝马",
drawOpt: createSideSingleColumn(
["520", "220", "S4", "525", "320"],
[400, 500, 600, 800, 1000],
"#63AECC"
),
},
{
name: "奔驰",
drawOpt: createSideSingleColumn(
["GML", "350", "S600", "SEL", "300"],
[400, 500, 600, 800, 1000],
"#54BF93"
),
},
{
name: "吉利",
drawOpt: createSideSingleColumn(
["330", "吉利星", "星耀", "星月", "帝豪"],
[400, 500, 600, 800, 1000],
"#CC9D12"
),
},
{
name: "大众",
drawOpt: createSideSingleColumn(
["途观", "速腾", "迈腾", "桑塔纳", "帕萨特"],
[400, 500, 600, 800, 1000],
"#CC7733"
),
},
{
name: "别克",
drawOpt: createSideSingleColumn(
["凯悦", "奥克拉", "君悦", "君越", "君威"],
[400, 500, 600, 800, 1000],
"#CC5B41"
),
},
],
}; };
}, },
created() { created() {
@ -111,12 +57,15 @@ export default {
methods: { methods: {
initData() { initData() {
this.form.token = this.getToken; this.form.token = this.getToken;
let arr = this.getBComparison; let arr = this.getMComparison;
let brands = []; let brands = [];
let models = [];
arr.forEach((ele) => { arr.forEach((ele) => {
brands.push(ele.name); brands.push(ele.brand);
models.push(ele.model);
}); });
this.form.sBrand = brands.toString(); this.form.sBrand = brands.toString();
this.form.sSeriesName = models.toString();
this.getData(); this.getData();
this.getTypeData(); this.getTypeData();
}, },
@ -126,11 +75,16 @@ export default {
getSourcetypeC(obj) getSourcetypeC(obj)
.then((res) => { .then((res) => {
let data = res.data || []; let data = res.data || [];
let brandList = []; let dx = [];
data.forEach((e) => { data.forEach((ele) => {
brandList.push(e.Name); let ab = ele.Data || {};
for(let key in ab) {
if(!dx.includes(key)) {
dx.push(key)
}
}
}); });
this.opt1 = createOpt(data, brandList); this.opt1 = createOpt(data, dx);
resolve(data); resolve(data);
}) })
.catch(() => { .catch(() => {
@ -141,9 +95,15 @@ export default {
getTypeData() { getTypeData() {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
let obj = Object.assign({}, this.getCtime2, this.form); let obj = Object.assign({}, this.getCtime2, this.form);
getContrastCount0528C(obj) getEventsSourceType0528(obj)
.then((res) => { .then((res) => {
let data = res.data || []; let data = res.data || [];
let brandList = [];
data.forEach((e) => {
e.Name = e.key;
brandList.push(e.key);
});
this.opt2 = createOpt(data, brandList);
resolve(data); resolve(data);
}) })
.catch(() => { .catch(() => {
@ -164,6 +124,10 @@ export default {
.bec-inner { .bec-inner {
width: 100%; width: 100%;
height: 412px; height: 412px;
.bec-inner-1 {
width: 100%;
height: calc(100% - 48px);
}
} }
.bec-one { .bec-one {
width: 100%; width: 100%;

@ -1,58 +1,121 @@
/* /*
* @Author: your name * @Author: your name
* @Date: 2021-10-15 15:15:27 * @Date: 2021-10-15 15:15:27
* @LastEditTime: 2021-10-15 17:43:04 * @LastEditTime: 2021-11-11 16:05:44
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/BrandComparison/channelDistribution/opt.js * @FilePath: /data-show/src/views/BrandComparison/channelDistribution/opt.js
*/ */
import { bigNumberTransform } from "@/utils/gol/dataTool"
/*series: [ import * as echarts from "echarts";
let colors = [new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#3373CC'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#63AECC'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#54BF93'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#CC9D12'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#CC7733'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#CC5B41'
},
{
offset: 1,
color: '#071a32'
}
], false)]
function createData(dataList = [], dx=[]) {
/*series: [
{ {
name: '奥迪', name: '奥迪',
type: 'bar', type: 'bar',
barGap: 0, barGap: 0,
barWidth: 20, barWidth: 16,
emphasis: { emphasis: {
focus: 'series' focus: 'series'
}, },
data: [320, 332, 301, 334, 390, 400] data: [320, 332, 301, 334, 390, 400]
},*/ },*/
function createData(dataList = []) {
let arr = []; let arr = [];
dataList.forEach(ele => { dataList.forEach(e => {
let a = [];
let Data = e.Data || {};
dx.forEach(e => {
a.push(Data[e])
})
let o = { let o = {
name: ele.Name, name: e.Name,
type: 'bar', type: 'bar',
barGap: 0, barWidth: 16,
barWidth: 20, barGap: '9%',
emphasis: { emphasis: {
focus: 'series' focus: 'series'
}, },
data: [ele.Data.新闻,ele.Data.论坛,ele.Data.微信,ele.Data.APP,ele.Data.微博,ele.Data.其他] data: a
}; };
arr.push(o) arr.push(o)
}) })
return arr; return arr;
} }
export default function createOpt(dataList = [],dx = []) {
export default function createOpt(dataList = [], brandList = []) { let info = createData(dataList, dx);
let info = createData(dataList);
return { return {
grid: { grid: {
top: "56px", top: 56,
left: "16px", left: 10,
right: "28px", right: "5%",
bottom: "16px", bottom: 10,
containLabel: true, containLabel: true,
}, },
color: colors,
legend: { legend: {
data: brandList,
textStyle: { //图例文字的样式 textStyle: { //图例文字的样式
color: '#fff' color: '#fff',
fontSize: 10
}, },
y: 12, y: 12,
x: 16 x: 16,
itemWidth: 12,
itemHeight: 12
}, },
tooltip: { tooltip: {
trigger: "axis", trigger: "axis",
@ -76,7 +139,7 @@ export default function createOpt(dataList = [], brandList = []) {
color: "#fff", color: "#fff",
}, },
}, },
data: ['新闻', '论坛', '微信', 'APP', '微博', "其他"] data: dx
} }
], ],
yAxis: [ yAxis: [
@ -88,6 +151,12 @@ export default function createOpt(dataList = [], brandList = []) {
color: "#FFF", color: "#FFF",
}, },
}, },
axisLabel: {
formatter: (value) => {
let str = bigNumberTransform(value);
return str;
}
},
splitLine: { splitLine: {
lineStyle: { lineStyle: {
type: "dashed", // y轴分割线类型 type: "dashed", // y轴分割线类型

@ -0,0 +1,174 @@
/*
* @Author: your name
* @Date: 2021-11-11 15:26:24
* @LastEditTime: 2021-11-11 15:27:33
* @LastEditors: Please set LastEditors
* @Description: 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
* @FilePath: /data-show/src/views/ModelComparison/brandEventComparison/opt1.js
*/
/*
* @Author: your name
* @Date: 2021-10-15 15:15:27
* @LastEditTime: 2021-11-11 15:25:56
* @LastEditors: Please set LastEditors
* @Description: In User Settings Edit
* @FilePath: /data-show/src/views/BrandComparison/channelDistribution/opt.js
*/
import { bigNumberTransform } from "@/utils/gol/dataTool"
import * as echarts from "echarts";
let colors = [new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#3373CC'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#63AECC'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#54BF93'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#CC9D12'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#CC7733'
},
{
offset: 1,
color: '#071a32'
}
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#CC5B41'
},
{
offset: 1,
color: '#071a32'
}
], false)]
function createData(dataList = []) {
/*series: [
{
name: '奥迪',
type: 'bar',
barGap: 0,
barWidth: 16,
emphasis: {
focus: 'series'
},
data: [320, 332, 301, 334, 390, 400]
},*/
let arr = [];
dataList.forEach(e => {
let o = {
name: e.key,
type: 'bar',
barWidth: 16,
barGap: '9%',
emphasis: {
focus: 'series'
},
data: e.value
};
arr.push(o)
})
return arr;
}
export default function createOpt(dataList = [],brandList = []) {
let info = createData(dataList);
return {
grid: {
top: 56,
left: 10,
right: "5%",
bottom: 10,
containLabel: true,
},
color: colors,
legend: {
data: brandList,
textStyle: { //图例文字的样式
color: '#fff',
fontSize: 10
},
y: 12,
x: 16,
itemWidth: 12,
itemHeight: 12
},
tooltip: {
trigger: "axis",
backgroundColor: "#08182F",
color: "#fff",
borderColor: "#3373CC",
textStyle: {
color: "#fff", //设置文字颜色
},
extraCssText: "box-shadow: 0px 0px 10px 0px #3373CC;",
},
xAxis: [
{
type: 'category',
axisTick: {
show: false,
},
axisLine: {
show: false,
lineStyle: {
color: "#fff",
},
},
data: ['新闻', '论坛', '微信', 'APP', '微博', "其他"]
}
],
yAxis: [
{
type: 'value',
axisLine: {
show: false,
lineStyle: {
color: "#FFF",
},
},
axisLabel: {
formatter: (value) => {
let str = bigNumberTransform(value);
return str;
}
},
splitLine: {
lineStyle: {
type: "dashed", // y轴分割线类型
color: "#012b4b",
},
},
}
],
series: info
}
}

@ -1,7 +1,7 @@
<!-- <!--
* @Author: your name * @Author: your name
* @Date: 2021-10-15 15:08:13 * @Date: 2021-10-15 15:08:13
* @LastEditTime: 2021-11-11 14:25:23 * @LastEditTime: 2021-11-11 16:29:45
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/BrandComparison/channelDistribution/index.vue * @FilePath: /data-show/src/views/BrandComparison/channelDistribution/index.vue
@ -27,7 +27,7 @@ export default {
token: "", token: "",
sBrand: "", sBrand: "",
sSeriesName: "", sSeriesName: "",
iContrastType: 2 iContrastType: 2,
}, },
opt: {}, opt: {},
}; };
@ -46,7 +46,7 @@ export default {
models.push(ele.model); models.push(ele.model);
}); });
this.form.sBrand = brands.toString(); this.form.sBrand = brands.toString();
this.form.sSeriesName =models.toString(); this.form.sSeriesName = models.toString();
this.getData(); this.getData();
}, },
getData() { getData() {
@ -56,11 +56,16 @@ export default {
getSourcetypeC(obj) getSourcetypeC(obj)
.then((res) => { .then((res) => {
let data = res.data || []; let data = res.data || [];
let brandList = []; let dx = [];
data.forEach(e => { data.forEach((ele) => {
brandList.push(e.Name) let ab = ele.Data || {};
}) for (let key in ab) {
this.opt = createOpt(data,brandList); if (!dx.includes(key)) {
dx.push(key);
}
}
});
this.opt = createOpt(data, dx);
this.load = false; this.load = false;
resolve(data); resolve(data);
}) })

@ -1,7 +1,7 @@
/* /*
* @Author: your name * @Author: your name
* @Date: 2021-10-15 15:15:27 * @Date: 2021-10-15 15:15:27
* @LastEditTime: 2021-11-11 14:48:43 * @LastEditTime: 2021-11-11 16:09:17
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/BrandComparison/channelDistribution/opt.js * @FilePath: /data-show/src/views/BrandComparison/channelDistribution/opt.js
@ -63,7 +63,7 @@ let colors = [new echarts.graphic.LinearGradient(0, 0, 0, 1, [
color: '#071a32' color: '#071a32'
} }
], false)] ], false)]
function createData(dataList = []) { function createData(dataList = [], dx=[]) {
/*series: [ /*series: [
{ {
name: '奥迪', name: '奥迪',
@ -77,6 +77,11 @@ function createData(dataList = []) {
},*/ },*/
let arr = []; let arr = [];
dataList.forEach(e => { dataList.forEach(e => {
let a = [];
let Data = e.Data || {};
dx.forEach(e => {
a.push(Data[e])
})
let o = { let o = {
name: e.Name, name: e.Name,
type: 'bar', type: 'bar',
@ -85,14 +90,14 @@ function createData(dataList = []) {
emphasis: { emphasis: {
focus: 'series' focus: 'series'
}, },
data: [e.Data['新闻'],e.Data['论坛'],e.Data['微信'],e.Data['短视频'],e.Data['微博'],e.Data['其他']] data: a
}; };
arr.push(o) arr.push(o)
}) })
return arr; return arr;
} }
export default function createOpt(dataList = [],brandList = []) { export default function createOpt(dataList = [],dx = []) {
let info = createData(dataList); let info = createData(dataList, dx);
return { return {
grid: { grid: {
top: 56, top: 56,
@ -103,7 +108,6 @@ export default function createOpt(dataList = [],brandList = []) {
}, },
color: colors, color: colors,
legend: { legend: {
data: brandList,
textStyle: { //图例文字的样式 textStyle: { //图例文字的样式
color: '#fff', color: '#fff',
fontSize: 10 fontSize: 10
@ -135,7 +139,7 @@ export default function createOpt(dataList = [],brandList = []) {
color: "#fff", color: "#fff",
}, },
}, },
data: ['新闻', '论坛', '微信', 'APP', '微博', "其他"] data: dx
} }
], ],
yAxis: [ yAxis: [

@ -1,7 +1,7 @@
<!-- <!--
* @Author: your name * @Author: your name
* @Date: 2021-10-15 15:34:26 * @Date: 2021-10-15 15:34:26
* @LastEditTime: 2021-11-11 14:27:39 * @LastEditTime: 2021-11-11 16:27:27
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/BrandComparison/keyMediaCommunicationComparison/index.vue * @FilePath: /data-show/src/views/BrandComparison/keyMediaCommunicationComparison/index.vue
@ -53,16 +53,17 @@ export default {
let obj = Object.assign({}, this.getCtime2, this.form); let obj = Object.assign({}, this.getCtime2, this.form);
this.load = true; this.load = true;
getSourceCount0528C(obj).then((res) => { getSourceCount0528C(obj).then((res) => {
let data = res.data; let data = res.data || [];
let dx = []; let dx = [];
let ds = [];
data.forEach((ele) => { data.forEach((ele) => {
let key = ele.key; let ab = ele.value || [];
let value = ele.value; ab.forEach(e => {
dx.push(key); if (!dx.includes(e.key)) {
ds.push(value); dx.push(e.key);
}
})
}); });
this.opt = createOpt(dx, ds); this.opt = createOpt(dx, data);
this.load = false; this.load = false;
}); });
}, },

@ -1,65 +1,109 @@
/* /*
* @Author: your name * @Author: your name
* @Date: 2021-10-09 11:01:19 * @Date: 2021-10-09 11:01:19
* @LastEditTime: 2021-11-11 14:49:46 * @LastEditTime: 2021-11-11 16:41:48
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/Index/spreadTheSound/opt.js * @FilePath: /data-show/src/views/Index/spreadTheSound/opt.js
*/ */
import * as echarts from "echarts"; import * as echarts from "echarts";
import { bigNumberTransform } from "@/utils/gol/dataTool" import { bigNumberTransform } from "@/utils/gol/dataTool"
let colors = ['rgba(203,118,58,1)', 'rgba(202,156,17,1)', 'rgba(90,203,156,1)', 'rgba(99,173,204,1)', 'rgba(55,113,190,1)', "rgba(138,191,66,1)", 'rgba(181,191,67,1)', 'rgba(203,91,65,1)'] let colors = [new echarts.graphic.LinearGradient(0, 0, 0, 1, [
let colors2 = ['rgba(203,118,58,0.6)', 'rgba(202,156,17,0.6)', 'rgba(90,203,156,0.6)', 'rgba(99,173,204,0.6)', 'rgba(55,113,190,0.6)', "rgba(138,191,66,0.6)", 'rgba(181,191,67,0.6)', 'rgba(203,91,65,0.6)']
function createData(ds = []) {
let arr = [];
for (let i = 0; i < ds.length; i++) {
let arr1 = ds[i];
for (let j = 0; j < arr1.length; j++) {
let n = arr.findIndex(ele => {
return ele.name === arr1[j].key;
})
if(n === -1) {
let obj =
{ {
name: arr1[j].key, offset: 0,
type: 'bar', color: '#3373CC'
stack: 'total',
barWidth: 24,
barGap: "-100%",
emphasis: {
focus: 'series'
}, },
itemStyle: { {
normal: { offset: 1,
//柱体的颜色 color: '#071a32'
//右1000表示从正右开始向左渐变 }
color: function () { ], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{ {
offset: 0, offset: 0,
color: colors[j] color: '#63AECC'
}, },
{ {
offset: 1, offset: 1,
color: colors2[j] color: '#071a32'
}
], false);
} }
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#54BF93'
},
{
offset: 1,
color: '#071a32'
} }
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#CC9D12'
}, },
data: [arr1[j].value] {
offset: 1,
color: '#071a32'
} }
arr.push(obj) ], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
} else { {
arr[n].data.push(arr1[j].value) offset: 0,
color: '#CC7733'
},
{
offset: 1,
color: '#071a32'
} }
], false), new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#CC5B41'
},
{
offset: 1,
color: '#071a32'
} }
], false)]
function createData(dataList = [], dx=[]) {
/*series: [
{
name: '奥迪',
type: 'bar',
barGap: 0,
barWidth: 16,
emphasis: {
focus: 'series'
},
data: [320, 332, 301, 334, 390, 400]
},*/
let arr = [];
dataList.forEach(ele => {
let a = [];
let Data = ele.value || [];
dx.forEach(e => {
Data.forEach(ex => {
if(ex.key === e) {
a.push(ex.value)
} }
})
})
let o = {
name: ele.key,
type: 'bar',
barWidth: 16,
barGap: -100,
stack: 'total',
emphasis: {
focus: 'series'
},
data: a
};
arr.push(o)
})
return arr; return arr;
} }
export default function createOpt(dx=[], ds=[]) { export default function createOpt(dx = [], ds = []) {
const data = createData(ds); const data = createData(ds,dx);
console.log(data)
return { return {
grid: { grid: {
left: 10, left: 10,
@ -78,6 +122,7 @@ export default function createOpt(dx=[], ds=[]) {
}, },
extraCssText: "box-shadow: 0px 0px 10px 0px #3373CC;" extraCssText: "box-shadow: 0px 0px 10px 0px #3373CC;"
}, },
color: colors,
legend: { legend: {
textStyle: { //图例文字的样式 textStyle: { //图例文字的样式
color: '#fff', color: '#fff',

@ -1,13 +1,13 @@
<!-- <!--
* @Author: your name * @Author: your name
* @Date: 2021-10-15 16:56:32 * @Date: 2021-10-15 16:56:32
* @LastEditTime: 2021-10-15 17:31:34 * @LastEditTime: 2021-11-11 16:44:15
* @LastEditors: Please set LastEditors * @LastEditors: Please set LastEditors
* @Description: In User Settings Edit * @Description: In User Settings Edit
* @FilePath: /data-show/src/views/BrandComparison/overallWordCloudComparison/index.vue * @FilePath: /data-show/src/views/BrandComparison/overallWordCloudComparison/index.vue
--> -->
<template> <template>
<div class="owcc-outter"> <div class="owcc-outter" v-loading="load">
<v-label-div title="整体词云对比"> </v-label-div> <v-label-div title="整体词云对比"> </v-label-div>
<div class="owcc-inner"> <div class="owcc-inner">
<div class="owcc-item" v-for="(item, index) in dataSource" :key="index"> <div class="owcc-item" v-for="(item, index) in dataSource" :key="index">
@ -38,9 +38,12 @@ export default {
data() { data() {
return { return {
opt: {}, opt: {},
load: false,
form: { form: {
token: "", token: "",
sBrand: "", sBrand: "",
sSeriesName: "",
iContrastType: 2
}, },
colors: [ colors: [
"#3373CC", "#3373CC",
@ -59,16 +62,20 @@ export default {
methods: { methods: {
initData() { initData() {
this.form.token = this.getToken; this.form.token = this.getToken;
let arr = this.getBComparison; let arr = this.getMComparison;
let brands = []; let brands = [];
let models = [];
arr.forEach((ele) => { arr.forEach((ele) => {
brands.push(ele.name); brands.push(ele.brand);
models.push(ele.model);
}); });
this.form.sBrand = brands.toString(); this.form.sBrand = brands.toString();
this.form.sSeriesName = models.toString();
this.getData(); this.getData();
}, },
getData() { getData() {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
this.load = true;
let obj = Object.assign({}, this.getCtime2, this.form); let obj = Object.assign({}, this.getCtime2, this.form);
getPositiveAndNegative0528C(obj) getPositiveAndNegative0528C(obj)
.then((res) => { .then((res) => {
@ -85,7 +92,7 @@ export default {
arr.push(obj); arr.push(obj);
}) })
this.dataSource = arr; this.dataSource = arr;
this.load = false;
resolve(data); resolve(data);
}) })
.catch(() => { .catch(() => {

Loading…
Cancel
Save