| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949 |
- let app = new Vue({
- el: "#app",
- data() {
- return {
- config5: {
- waitTime: 2000,
- header: ["单位名称", "平均工资涨幅", ''],
- data: [
- ["山焦财务", '<span class="red"><span class="listText">-12%</span><span class="redImg"></span></span>'],
- ["山焦担保", '<span class="green"><span class="listText">4%</span><span class="greedImg"></span></span>'],
- ["山焦股份", '<span class="green"><span class="listText">6%</span><span class="greedImg"></span></span>'],
- ["山焦国华", '<span class="green"><span class="listText">20%</span><span class="greedImg"></span></span>'],
- ["山焦国华", '<span class="green"><span class="listText">9%</span><span class="greedImg"></span></span>'],
- ["山焦财务", '<span class="red"><span class="listText">-1%</span><span class="redImg"></span></span>'],
- ["山焦担保", '<span class="green"><span class="listText">4%</span><span class="greedImg"></span></span>'],
- ["山焦股份", '<span class="green"><span class="listText">6%</span><span class="greedImg"></span></span>'],
- ["山焦国华", '<span class="green"><span class="listText">20%</span><span class="greedImg"></span></span>'],
- ["山焦国华", '<span class="green"><span class="listText">9%</span><span class="greedImg"></span></span>']
- ],
- align: ["center", "center"],
- headerBGC: "#153A62",
- oddRowBGC: "#061F42",
- evenRowBGC: "#0C284A",
- },
- config1: {
- waitTime: 2000,
- rowNum: 1,
- data: [
- ["山焦财务", '<span class="red"><span class="listText">-12%</span><span class="redImg"></span></span>'],
- ["山焦担保", '<span class="green"><span class="listText">4%</span><span class="greedImg"></span></span>'],
- ["山焦股份", '<span class="green"><span class="listText">6%</span><span class="greedImg"></span></span>'],
- ["山焦国华", '<span class="green"><span class="listText">20%</span><span class="greedImg"></span></span>'],
- ["山焦国华", '<span class="green"><span class="listText">9%</span><span class="greedImg"></span></span>'],
- ["山焦财务", '<span class="red"><span class="listText">-1%</span><span class="redImg"></span></span>'],
- ["山焦担保", '<span class="green"><span class="listText">4%</span><span class="greedImg"></span></span>'],
- ["山焦股份", '<span class="green"><span class="listText">6%</span><span class="greedImg"></span></span>'],
- ["山焦国华", '<span class="green"><span class="listText">20%</span><span class="greedImg"></span></span>'],
- ["山焦国华", '<span class="green"><span class="listText">9%</span><span class="greedImg"></span></span>']
- ],
- align: ["center", "center"],
- headerBGC: "#153A62",
- oddRowBGC: "#061F42",
- evenRowBGC: "#0C284A",
- },
- }
- },
- mounted() {
- this.$nextTick(() => {
- let organization = this.$refs.organization
- this.initOrganization(organization, "组织分布")
- let mobilize = this.$refs.mobilize
- this.initOrganization(mobilize,)
- let industry = this.$refs.industry
- this.initOrganization(industry, "产业分布")
- let sequence = this.$refs.sequence
- this.initOrganization(sequence, "", { x: ["管理序列", "技术序列", "操作序列"], y: [1200, 680, 562] })
- let serviceAge = this.$refs.serviceAge
- this.initLineEcharts(serviceAge)
- let level = this.$refs.level
- this.initLineElseEcharts(level)
- let initChartR1 = this.$refs.initChartR1
- this.initChartR1(initChartR1)
- let initChartsBig = this.$refs.initChartsBig
- this.initChartsBig(initChartsBig)
- let leftEnd = this.$refs.leftEnd
- this.initOrganization(leftEnd)
- let echarts90 = this.$refs.echarts90
- this.initLineElseEcharts(echarts90)
- })
- },
- methods: {
- initOrganization(el, title = "", data = { x: ["集团本部", "山焦财务", "山焦担保", "山焦股份", "山焦国华", "山焦机电", "山焦人力", "山焦民爆", "山焦事业", "山焦投资"], y: [1200, 680, 562, 268, 717, 843, 987, 126, 723, 569] }) {
- let chart = echarts.init(el);
- let option = {
- title: {
- top: 5,
- left: "center",
- text: title,
- textStyle: {
- color: "#5EB7FF",
- fontWeight: "normal",
- fontSize: 32
- }
- },
- grid: {
- top: 60,
- right: 40,
- left: 105,
- bottom: 40,
- },
- tooltip: {
- show: true,
- trigger: "axis",
- axisPointer: {
- // 坐标轴指示器,坐标轴触发有效
- type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
- },
- },
- xAxis: {
- data: data.x,
- axisTick: {
- show: false,
- },
- // x轴的字体颜色
- axisLabel: {
- interval: 0,
- // rotate: 40,
- textStyle: {
- color: "white",
- fontSize: 30,
- },
- },
- //y轴线的颜色以及宽度
- axisLine: {
- show: true,
- lineStyle: {
- color: "#1E5389",
- width: 1,
- type: "solid",
- },
- },
- },
- yAxis: {
- name: "单位/个",
- axisTick: {
- lineStyle: {
- color: "#18416F",
- },
- },
- // y轴的字体颜色
- axisLabel: {
- textStyle: {
- color: "white",
- fontSize: 30,
- },
- },
- nameTextStyle: {
- fontSize: 30,
- },
- splitLine: {
- show: true,
- lineStyle: {
- color: "#204561",
- width: 1,
- type: "dotted",
- },
- },
- //y轴线的颜色以及宽度
- axisLine: {
- show: true,
- lineStyle: {
- color: "#1E5389",
- width: 1,
- type: "solid",
- },
- },
- },
- series: [
- {
- name: "",
- type: "bar",
- data: data.y,
- showBackground: true,
- backgroundStyle: {
- color: "#18416F",
- },
- barWidth: "30%",
- itemStyle: {
- barBorderRadius: [30, 30, 0, 0],
- color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
- {
- offset: 0,
- color: "#02355C",
- }, //柱图渐变色
- {
- offset: 1,
- color: "#40A9FF",
- },
- ]),
- },
- }
- ],
- legend: {
- data: ["入池人数", "出池人数"],
- textStyle: {
- // 图列内容样式
- color: "#fff", // 字体颜色
- // fontSize: "10",
- },
- right: 30,
- icon: "roundRect",
- // 小图标的宽高
- itemHeight: 5,
- },
- };
- chart.setOption(option);
- tools.loopShowTooltip(chart, option, {
- nterval: 2000,
- loopSeries: true,
- });
- },
- initLineEcharts(el) {
- let chart = echarts.init(el);
- let option = {
- grid: {
- top: 15,
- right: 15,
- left: 45,
- bottom: 45,
- },
- tooltip: {
- show: true,
- trigger: "axis",
- axisPointer: {
- lineStyle: {
- color: "#ddd",
- },
- },
- },
- legend: {
- textStyle: {
- // 图列内容样式
- color: "#fff", // 字体颜色
- // fontSize: "10",
- },
- right: 30,
- icon: "roundRect",
- // 小图标的宽高
- itemHeight: 5
- },
- xAxis: {
- type: "category",
- data: ["5年以下", "6-10年", "11-15年", "16-20年", '21-25年', '26-30年', '30年以上'],
- boundaryGap: false,
- splitLine: {
- show: false,
- interval: "auto",
- },
- axisTick: {
- show: false,
- },
- axisLine: {
- lineStyle: {
- color: "#7ECEF4",
- },
- },
- axisLabel: {
- interval: 0,
- rotate: 40,
- margin: 10,
- textStyle: {
- // fontSize: 10,
- color: "#fff",
- },
- },
- },
- yAxis: {
- type: "value",
- splitLine: {
- show: true,
- lineStyle: {
- color: "#204561",
- width: 1,
- type: "dotted",
- },
- },
- axisTick: {
- show: false,
- },
- axisLine: {
- lineStyle: {
- color: "#7ECEF4",
- },
- },
- axisLabel: {
- margin: 10,
- textStyle: {
- fontSize: 10,
- color: "#fff",
- },
- },
- },
- series: [
- {
- name: "",
- type: "line",
- smooth: false,
- showSymbol: true, // 节点长显
- symbol: 'image://' + '',
- symbolSize: 30,
- data: ["1100", "400", "608", "811", '358', '698', '125', '765'],
- areaStyle: {
- normal: {
- color: new echarts.graphic.LinearGradient(
- 0,
- 0,
- 0,
- 1,
- [
- {
- offset: 0,
- color: "#40A9FF",
- },
- {
- offset: 1,
- color: "#051F41",
- },
- ],
- false
- ),
- },
- },
- itemStyle: {
- normal: {
- color: "#40A9FF",
- },
- },
- lineStyle: {
- normal: {
- width: 2,
- },
- },
- }, {
- name: "",
- type: "line",
- smooth: false,
- showSymbol: true, // 节点长显
- symbol: 'image://' + '',
- symbolSize: 30,
- data: ["100", "900", "68", "981", '1358', '628', '525', '565'],
- areaStyle: {
- normal: {
- color: new echarts.graphic.LinearGradient(
- 0,
- 0,
- 0,
- 1,
- [
- {
- offset: 0,
- color: "#45DAD1",
- },
- {
- offset: 1,
- color: "#051F41",
- },
- ],
- false
- ),
- },
- },
- itemStyle: {
- normal: {
- color: "#45DAD1",
- },
- },
- lineStyle: {
- normal: {
- width: 2,
- },
- },
- }
- ],
- };
- chart.setOption(option);
- tools.loopShowTooltip(chart, option, {
- nterval: 2000,
- loopSeries: true,
- });
- },
- initLineElseEcharts(el) {
- let chart = echarts.init(el);
- let option = {
- grid: {
- top: 15,
- right: 15,
- left: 45,
- bottom: 45,
- },
- tooltip: {
- show: true,
- trigger: "axis",
- axisPointer: {
- lineStyle: {
- color: "#ddd",
- },
- },
- },
- legend: {
- textStyle: {
- // 图列内容样式
- color: "#fff", // 字体颜色
- // fontSize: "10",
- },
- right: 30,
- icon: "roundRect",
- // 小图标的宽高
- itemHeight: 5
- },
- xAxis: {
- type: "category",
- data: ["5年以下", "6-10年", "11-15年", "16-20年", '21-25年', '26-30年', '30年以上'],
- boundaryGap: false,
- splitLine: {
- show: false,
- interval: "auto",
- },
- axisTick: {
- show: false,
- },
- axisLine: {
- lineStyle: {
- color: "#7ECEF4",
- },
- },
- axisLabel: {
- interval: 0,
- rotate: 40,
- margin: 10,
- textStyle: {
- // fontSize: 10,
- color: "#fff",
- },
- },
- },
- yAxis: {
- type: "value",
- splitLine: {
- show: true,
- lineStyle: {
- color: "#204561",
- width: 1,
- type: "dotted",
- },
- },
- axisTick: {
- show: false,
- },
- axisLine: {
- lineStyle: {
- color: "#7ECEF4",
- },
- },
- axisLabel: {
- margin: 10,
- textStyle: {
- fontSize: 10,
- color: "#fff",
- },
- },
- },
- series: [
- {
- name: "",
- type: "line",
- smooth: false,
- showSymbol: true, // 节点长显
- symbol: 'image://' + '',
- symbolSize: 30,
- data: ["1100", "400", "608", "811", '358', '698', '125', '765'],
- areaStyle: {
- normal: {
- color: new echarts.graphic.LinearGradient(
- 0,
- 0,
- 0,
- 1,
- [
- {
- offset: 0,
- color: "#40A9FF",
- },
- {
- offset: 1,
- color: "#051F41",
- },
- ],
- false
- ),
- },
- },
- itemStyle: {
- normal: {
- color: "#40A9FF",
- },
- },
- lineStyle: {
- normal: {
- width: 2,
- },
- },
- }
- ],
- };
- chart.setOption(option);
- tools.loopShowTooltip(chart, option, {
- nterval: 2000,
- loopSeries: true,
- });
- },
- initChartR1(el) {
- let myChart = echarts.init(el)
- data = echarts2;
- arrName = getArrayValue(data, "name");
- arrValue = getArrayValue(data, "value");
- sumValue = eval(arrValue.join("+"));
- objData = array2obj(data, "name");
- optionData = getData(data);
- function getArrayValue(array, key) {
- var key = key || "value";
- var res = [];
- if (array) {
- array.forEach(function (t) {
- res.push(t[key]);
- });
- }
- return res;
- }
- function array2obj(array, key) {
- var resObj = {};
- for (var i = 0; i < array.length; i++) {
- resObj[array[i][key]] = array[i];
- }
- return resObj;
- }
- function getData(data) {
- var res = {
- series: [],
- yAxis: [],
- };
- for (let i = 0; i < data.length; i++) {
- // console.log([70 - i * 15 + '%', 67 - i * 15 + '%']);
- res.series.push({
- name: "",
- type: "pie",
- clockWise: false, //顺时加载
- hoverAnimation: false, //鼠标移入变大
- radius: [53 - i * 15 + "%", 48 - i * 15 + "%"],
- center: ["35%", "50%"],
- label: {
- show: false,
- },
- itemStyle: {
- label: {
- show: false,
- },
- labelLine: {
- show: false,
- },
- borderWidth: 5,
- },
- data: [
- {
- value: data[i].value,
- name: data[i].name,
- },
- {
- value: sumValue - data[i].value,
- name: "",
- itemStyle: {
- color: "rgba(0,0,0,0)",
- borderWidth: 0,
- },
- tooltip: {
- show: false,
- },
- hoverAnimation: false,
- },
- ],
- });
- res.series.push({
- name: "",
- type: "pie",
- silent: true,
- z: 1,
- clockWise: false, //顺时加载
- hoverAnimation: false, //鼠标移入变大
- radius: [53 - i * 15 + "%", 48 - i * 15 + "%"],
- center: ["35%", "50%"],
- label: {
- show: false,
- },
- itemStyle: {
- label: {
- show: false,
- },
- labelLine: {
- show: false,
- },
- borderWidth: 5,
- },
- data: [
- {
- value: 7.5,
- itemStyle: {
- color: "rgb(3, 31, 62)",
- borderWidth: 0,
- },
- tooltip: {
- show: false,
- },
- hoverAnimation: false,
- },
- {
- value: 2.5,
- name: "",
- itemStyle: {
- color: "rgba(0,0,0,0)",
- borderWidth: 0,
- },
- tooltip: {
- show: false,
- },
- hoverAnimation: false,
- },
- ],
- });
- res.yAxis.push(((data[i].value / sumValue) * 100).toFixed(2) + "%");
- }
- return res;
- }
- let option = {
- graphic: {
- elements: [{
- type: 'image',//需要填充图片,配置image,如果不需要图片可以配置其他的, text, circle, sector, ring, polygon, polyline, rect, line, bezierCurve, arc, group,
- style: {
- image: './images/loop.png', //这里添加图片地址
- width: 320,
- height: 320
- },
- left: '150',//
- top: 'middle' //配置图片居中
- }]
- },
- legend: {
- show: true,
- icon: "circle",
- top: "center",
- left: "70%",
- data: arrName,
- width: 50,
- formatter: function (name) {
- return (
- "{title|" + name + "}\n{value|" + objData[name].value + "} {title|项}"
- );
- },
- textStyle: {
- rich: {
- title: {
- fontSize: 32,
- lineHeight: 30,
- color: "rgb(0, 178, 246)",
- },
- value: {
- fontSize: 32,
- lineHeight: 40,
- color: "#fff",
- },
- },
- },
- },
- tooltip: {
- show: false,
- normal: {
- show: false,
- trigger: "item",
- label: {
- margin: 10, // label 距离轴的距离
- color: '#FFF', // 文字的颜色
- fontStyle: 'normal', // 文字字体的风格('normal',无样式;'italic',斜体;'oblique',倾斜字体)
- fontWeight: 'normal', // 文字字体的粗细('normal',无样式;'bold',加粗;'bolder',加粗的基础上再加粗;'lighter',变细;数字定义粗细也可以,取值范围100至700)
- fontSize: '30', // 文字字体大小
- lineHeight: '50', // 行高
- },
- },
- // formatter: "{a}<br>{b}:{c}({d}%)666",
- textStyle: {
- color: '#FFF', // 文字的颜色
- fontStyle: 'normal', // 文字字体的风格('normal',无样式;'italic',斜体;'oblique',倾斜字体)
- fontWeight: 'normal', // 文字字体的粗细('normal',无样式;'bold',加粗;'bolder',加粗的基础上再加粗;'lighter',变细;数字定义粗细也可以,取值范围100至700)
- },
- formatter: data => {
- console.log(data)
- // 小圆点
- return `<br /><span style="display:inline-block;border-radius:50%;margin-right:10px; width:7px;height:7px;background-color:blue"></span>${data.name}:${data.percent}`
- },
- },
- color: [
- "rgb(24, 183, 142)",
- "rgb(1, 179, 238)",
- "rgb(22, 75, 205)",
- "rgb(52, 52, 176)",
- ],
- grid: {
- top: "21%",
- bottom: "48%",
- left: "36%",
- containLabel: false,
- },
- yAxis: [
- {
- type: "category",
- inverse: true,
- axisLine: {
- show: false,
- },
- axisTick: {
- show: false,
- },
- axisLabel: {
- interval: 0,
- inside: true,
- textStyle: {
- color: "#fff",
- fontSize: 24,
- },
- show: true,
- },
- data: optionData.yAxis,
- },
- ],
- xAxis: [
- {
- show: false,
- },
- ],
- series: optionData.series,
- }
- myChart.setOption(option)
- tools.loopShowTooltip(myChart, option, {
- nterval: 2000,
- loopSeries: true,
- });
- },
- initChartsBig(el) {
- let chart = echarts.init(el);
- let option = {
- backgroundColor: "#0B1837",
- color: ["#EAEA26", "#906BF9", "#FE5656", "#01E17E", "#3DD1F9", "#FFAD05"],
- // title: {
- // text: '网络/安全设备',
- // left: '60',
- // top: 0,
- // textAlign: 'center',
- // textStyle: {
- // color: '#fff',
- // fontSize: 14,
- // fontWeight: 0
- // }
- // },
- grid: {
- left: -100,
- top: 50,
- bottom: 10,
- right: 10,
- containLabel: true
- },
- tooltip: {
- trigger: 'item',
- textStyle:{
- fontSize: 50
- },
- formatter: "{b} : {c} ({d}%)"
- },
- legend: {
- type: "scroll",
- orient: "vartical",
- // x: "right",
- top: "center",
- right: "15",
- // bottom: "0%",
- itemWidth: 30,
- itemHeight: 12,
- itemGap: 16,
- textStyle: {
- color: '#A3E2F4',
- fontSize: 30,
- fontWeight: 0
- },
- data: ['IDS', 'VPN', '交换机', '防火墙', 'WAF', '堡垒机']
- },
- polar: {},
- angleAxis: {
- interval: 1,
- type: 'category',
- data: [],
- z: 10,
- axisLine: {
- show: false,
- lineStyle: {
- color: "#0B4A6B",
- width: 1,
- type: "solid"
- },
- },
- axisLabel: {
- interval: 0,
- show: true,
- color: "#0B4A6B",
- margin: 8,
- fontSize: 16
- },
- },
- radiusAxis: {
- min: 40,
- max: 120,
- interval: 20,
- axisLine: {
- show: false,
- lineStyle: {
- color: "#0B3E5E",
- width: 1,
- type: "solid"
- },
- },
- axisLabel: {
- formatter: '{value} %',
- show: false,
- padding: [0, 0, 20, 0],
- color: "#0B3E5E",
- fontSize: 30
- },
- splitLine: {
- lineStyle: {
- color: "#0B3E5E",
- width: 2,
- type: "solid"
- }
- }
- },
- calculable: true,
- series: [{
- type: 'pie',
- radius: ["5%", "10%"],
- hoverAnimation: false,
- labelLine: {
- normal: {
- show: false,
- length: 30,
- length2: 55
- },
- emphasis: {
- show: false
- }
- },
- data: [{
- name: '',
- value: 0,
- tooltip:{show: false},
- itemStyle: {
- normal: {
- color: "#0B4A6B"
- }
- }
- }]
- }, {
- type: 'pie',
- radius: ["90%", "95%"],
- hoverAnimation: false,
- labelLine: {
- normal: {
- show: false,
- length: 30,
- length2: 55
- },
- emphasis: {
- show: false
- }
- },
- name: "",
- data: [{
- name: '',
- value: 0,
- tooltip:{show: false},
- itemStyle: {
- normal: {
- color: "#0B4A6B"
- }
- }
- }]
- }, {
- stack: 'a',
- type: 'pie',
- radius: ['20%', '80%'],
- roseType: 'area',
- zlevel: 10,
- label: {
- normal: {
- show: true,
- formatter: "{c}",
- textStyle: {
- fontSize: 35,
- },
- position: 'outside'
- },
- emphasis: {
- show: true
- }
- },
- labelLine: {
- normal: {
- show: true,
- length: 20,
- length2: 55
- },
- emphasis: {
- show: false
- }
- },
- data: [{
- value: 10,
- name: 'IDS'
- },
- {
- value: 5,
- name: 'VPN'
- },
- {
- value: 15,
- name: '交换机'
- },
- {
- value: 25,
- name: '防火墙'
- },
- {
- value: 20,
- name: 'WAF'
- },
- {
- value: 35,
- name: '堡垒机'
- }
- ]
- },]
- }
- chart.setOption(option);
- tools.loopShowTooltip(chart, option, {
- nterval: 2000,
- loopSeries: true,
- });
- }
- },
- })
|