Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
yma16
可视化 csdn 数据
提交
4735d8e5
可
可视化 csdn 数据
项目概览
yma16
/
可视化 csdn 数据
该项目与 Fork 源项目分叉
Fork自
inscode / VueJS
通知
17
Star
15
Fork
10
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
可
可视化 csdn 数据
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
4735d8e5
编写于
5月 15, 2024
作者:
Q
qq_38870145
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Auto Commit
上级
eaa7ad69
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
24 addition
and
12 deletion
+24
-12
src/components/GameChart.vue
src/components/GameChart.vue
+24
-12
未找到文件。
src/components/GameChart.vue
浏览文件 @
4735d8e5
...
@@ -30,6 +30,7 @@
...
@@ -30,6 +30,7 @@
<div
style=
"display:flex;justify-content: space-between;"
>
<div
style=
"display:flex;justify-content: space-between;"
>
<div
style=
"flex:1; min-width:600px;height:600px;border: 1px solid #333;"
>
<div
style=
"flex:1; min-width:600px;height:600px;border: 1px solid #333;"
>
<div
style=
"width: 100%;min-width:600px;font-weight: 600;text-align: center;"
>
{{
state
.
clickCity
}}
</div>
<div
style=
"width: 100%;min-width:600px;font-weight: 600;text-align: center;"
>
{{
state
.
clickCity
}}
</div>
<div
style=
"width: 100%;min-width:600px;font-weight: 600;text-align: left;"
>
渲染地图时间:
{{
state
.
echartDuration
}}
ms
</div>
<div
id=
"barChartId"
style=
"min-width:600px;height:600px;margin: 0 auto;"
>
<div
id=
"barChartId"
style=
"min-width:600px;height:600px;margin: 0 auto;"
>
</div>
</div>
</div>
</div>
...
@@ -63,6 +64,7 @@ const props = defineProps({
...
@@ -63,6 +64,7 @@ const props = defineProps({
})
})
const
state
=
reactive
({
const
state
=
reactive
({
echartDuration
:
0
,
title
:
'
vue3 ts antd 参赛选手所在城市
'
,
title
:
'
vue3 ts antd 参赛选手所在城市
'
,
clickCity
:
'
全国
'
,
clickCity
:
'
全国
'
,
maxCityNum
:
0
,
maxCityNum
:
0
,
...
@@ -76,7 +78,7 @@ const state = reactive({
...
@@ -76,7 +78,7 @@ const state = reactive({
airData
:
[],
airData
:
[],
exportLoading
:
false
,
exportLoading
:
false
,
columns
:
tableGameColumns
,
columns
:
tableGameColumns
,
totalDataSource
:[],
totalDataSource
:
[],
dataSource
:
[],
dataSource
:
[],
echartInstance
:
undefined
,
echartInstance
:
undefined
,
pagination
:
{
pagination
:
{
...
@@ -104,7 +106,7 @@ function initDataSource() {
...
@@ -104,7 +106,7 @@ function initDataSource() {
imgSrc
:
gameJson
[
uid
].
imgSrc
,
imgSrc
:
gameJson
[
uid
].
imgSrc
,
url
:
gameJson
[
uid
].
url
,
url
:
gameJson
[
uid
].
url
,
ip
:
gameJson
[
uid
].
ip
.
split
(
'
:
'
)[
1
],
ip
:
gameJson
[
uid
].
ip
.
split
(
'
:
'
)[
1
],
status
:
isTruth
?
'
有效
'
:
gameJson
[
uid
].
name
===
'
yma16
'
?
'
赛道负责人
'
:
'
无效
'
status
:
isTruth
?
'
有效
'
:
gameJson
[
uid
].
name
===
'
yma16
'
?
'
赛道负责人
'
:
'
无效
'
})
})
// 有效人数
// 有效人数
if
(
isTruth
)
{
if
(
isTruth
)
{
...
@@ -112,21 +114,21 @@ function initDataSource() {
...
@@ -112,21 +114,21 @@ function initDataSource() {
}
}
state
.
total
+=
1
state
.
total
+=
1
})
})
state
.
totalDataSource
=
state
.
dataSource
state
.
totalDataSource
=
state
.
dataSource
state
.
pagination
.
current
=
1
state
.
pagination
.
current
=
1
state
.
totlaNum
=
state
.
total
state
.
totlaNum
=
state
.
total
}
}
function
filterDatasource
(
name
){
function
filterDatasource
(
name
)
{
return
state
.
totalDataSource
.
filter
(
item
=>
{
return
state
.
totalDataSource
.
filter
(
item
=>
{
return
name
&&
name
.
toString
().
includes
(
item
.
ip
)
return
name
&&
name
.
toString
().
includes
(
item
.
ip
)
})
||
[]
})
||
[]
}
}
function
filterName
(
name
)
{
function
filterName
(
name
)
{
state
.
clickCity
=
name
state
.
clickCity
=
name
state
.
dataSource
=
filterDatasource
(
name
)
state
.
dataSource
=
filterDatasource
(
name
)
state
.
total
=
state
.
dataSource
.
length
state
.
total
=
state
.
dataSource
.
length
state
.
pagination
.
current
=
1
state
.
pagination
.
current
=
1
}
}
...
@@ -134,6 +136,8 @@ function filterMapName(name) {
...
@@ -134,6 +136,8 @@ function filterMapName(name) {
return
filterDatasource
(
name
)
return
filterDatasource
(
name
)
}
}
onBeforeMount
(()
=>
{
onBeforeMount
(()
=>
{
// 标记开始时刻
performance
.
mark
(
'
render-echart-start
'
)
echarts
.
registerMap
(
'
chinaJson
'
,
chinaJson
)
echarts
.
registerMap
(
'
chinaJson
'
,
chinaJson
)
})
})
...
@@ -270,14 +274,14 @@ function renderEchartBar() {
...
@@ -270,14 +274,14 @@ function renderEchartBar() {
formatter
:
(
params
)
=>
{
formatter
:
(
params
)
=>
{
const
{
name
}
=
params
.
data
const
{
name
}
=
params
.
data
const
filterData
=
filterMapName
(
name
)
const
filterData
=
filterMapName
(
name
)
let
isTruthCount
=
0
let
isTruthCount
=
0
const
strInfo
=
filterData
.
map
(
item
=>
{
const
strInfo
=
filterData
.
map
(
item
=>
{
if
(
item
.
status
===
'
有效
'
)
{
if
(
item
.
status
===
'
有效
'
)
{
isTruthCount
++
isTruthCount
++
}
}
return
`<img src=
${
item
.
imgSrc
}
width='20' height='20'/>
${
item
.
name
}
(
${
item
.
status
}
)`
return
`<img src=
${
item
.
imgSrc
}
width='20' height='20'/>
${
item
.
name
}
(
${
item
.
status
}
)`
}).
join
(
'
<br>
'
)
}).
join
(
'
<br>
'
)
state
.
provinceIsTruthCount
=
isTruthCount
state
.
provinceIsTruthCount
=
isTruthCount
const
value
=
filterData
.
length
const
value
=
filterData
.
length
return
`地区:
${
name
}
<br>
return
`地区:
${
name
}
<br>
报名总人数:
${
value
}
<br>
报名总人数:
${
value
}
<br>
...
@@ -349,7 +353,7 @@ function renderEchartBar() {
...
@@ -349,7 +353,7 @@ function renderEchartBar() {
],
],
}
}
console
.
log
(
'
option
'
,
option
)
console
.
log
(
'
option
'
,
option
)
// 使用刚指定的配置项和数据显示图表。
// 使用刚指定的配置项和数据显示图表。
myChart
.
setOption
(
option
,
true
);
myChart
.
setOption
(
option
,
true
);
// 监听
// 监听
...
@@ -359,6 +363,14 @@ function renderEchartBar() {
...
@@ -359,6 +363,14 @@ function renderEchartBar() {
filterName
(
params
.
name
)
filterName
(
params
.
name
)
});
});
window
.
onresize
=
myChart
.
resize
;
window
.
onresize
=
myChart
.
resize
;
performance
.
mark
(
'
render-echart-end
'
)
const
measure
=
performance
.
measure
(
'
render-echart-duration
'
,
'
render-echart-start
'
,
'
render-echart-end
'
)
console
.
log
(
'
measure
'
,
measure
)
console
.
log
(
'
measure type
'
,
typeof
measure
)
const
duration
=
measure
.
duration
console
.
log
(
'
duration
'
,
duration
)
state
.
echartDuration
=
duration
}
}
onUnmounted
(()
=>
{
onUnmounted
(()
=>
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录