Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
yma16
cat
提交
0367277f
C
cat
项目概览
yma16
/
cat
与 Fork 源项目一致
Fork自
yma16 / 可视化 csdn 数据
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
cat
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
0367277f
编写于
7月 01, 2023
作者:
6
63f1bb74d2451104dc7d8b9f
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Auto Commit
上级
84b0f49a
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
90 addition
and
16 deletion
+90
-16
src/components/SearchGrade.vue
src/components/SearchGrade.vue
+30
-9
src/components/const.js
src/components/const.js
+2
-7
src/components/writeExcel.js
src/components/writeExcel.js
+58
-0
未找到文件。
src/components/SearchGrade.vue
浏览文件 @
0367277f
...
...
@@ -4,9 +4,11 @@ import Author from './Author.vue'
import
{
tableColumns
}
from
'
./const
'
import
{
getRemoteCsdnGrade
}
from
'
../service/csdnApi
'
import
{
onMounted
,
reactive
,
onUnmounted
}
from
'
vue
'
;
import
{
exportExcel
}
from
'
./writeExcel
'
const
state
=
reactive
({
title
:
'
csdn用户根据id快速查分数改文章
'
,
title
:
'
csdn用户根据id快速查分数改文章
'
,
loading
:
false
,
exportLoading
:
false
,
searchValue
:
localStorage
.
getItem
(
'
csdnUid
'
)
||
''
,
firstChart
:
null
,
columns
:
tableColumns
,
...
...
@@ -152,8 +154,8 @@ function initFirstData() {
show
:
true
,
position
:
'
middle
'
,
color
:
'
red
'
,
lineHeight
:
35
,
backgroundColor
:
'
rgba(255,255,255.7)
'
,
lineHeight
:
35
,
backgroundColor
:
'
rgba(255,255,255.7)
'
,
formatter
:
(
params
)
=>
{
console
.
log
(
'
params markline
'
,
params
)
return
params
.
name
+
"
:
"
+
params
.
value
...
...
@@ -184,6 +186,17 @@ function initFirstData() {
}
});
const
exportTableDataFunc
=
()
=>
{
if
(
!
state
.
dataSource
||
state
.
dataSource
.
length
===
0
)
{
return
window
.
alert
(
'
表格数据为空
'
)
}
state
.
exportLoading
=
true
exportExcel
(
state
.
dataSource
,
'
用户质量分
'
).
then
(
res
=>
{
state
.
exportLoading
=
false
console
.
log
(
'
res
'
,
res
)
})
}
onMounted
(()
=>
{
const
storageUid
=
localStorage
.
getItem
(
'
csdnUid
'
)
console
.
log
(
'
window.localStorage
'
,
localStorage
)
...
...
@@ -215,6 +228,7 @@ function initFirstData() {
onSearch
()
}
})
}
</
script
>
...
...
@@ -231,8 +245,8 @@ function initFirstData() {
<div
style=
"width:100px;line-height: 32px;"
>
csdn用户id:
</div><a-input-search
v-model:value=
"state.searchValue"
:disabled=
"state.loading"
placeholder=
"输入用户id(如 qq_38870145)"
enter-button
@
search=
"onSearch"
/>
</div>
<br
>
<a-button
type=
"primary"
@
click=
"exportTableDataFunc"
style=
"margin: 10px 0;"
:loading=
"state.exportLoading"
>
导出
</a-button
>
<div>
<a-table
:scroll=
"
{ x: 800, y: 600 }" :columns="state.columns" :data-source="state.dataSource"
:loading="state.loading" :pagination="state.pagination" bordered style="border-bottom:1px solid #f0f0f0;">
...
...
@@ -242,11 +256,18 @@ function initFirstData() {
{{
record
.
url
}}
</a>
</
template
>
<
template
v-if=
"column.key === 'option'"
>
<
template
v-else-if=
"column.key === 'score'"
>
<span>
<a-tag
:color=
"record.score
<
60
?
'
volcano
'
:
record.score
>
80 ? 'geekblue' : 'green'">
{{
record
.
score
}}
</a-tag>
</span>
</
template
>
<
template
v-else-if=
"column.key === 'option'"
>
<a-tooltip
placement=
"topLeft"
:title=
"record.editUrl"
>
<a
:href=
"record.editUrl"
target=
"_blank"
>
编辑文章
</a>
<a
:href=
"record.editUrl"
target=
"_blank"
>
编辑文章
</a>
</a-tooltip>
</
template
>
</template>
...
...
src/components/const.js
浏览文件 @
0367277f
export
const
tableColumns
=
[
{
title
:
'
序号
'
,
dataIndex
:
'
index
'
,
fixed
:
true
},
{
title
:
'
文章名称
'
,
dataIndex
:
'
title
'
,
fixed
:
true
...
...
@@ -28,7 +24,7 @@ export const tableColumns= [
sorter
:
(
a
,
b
)
=>
a
.
diggCount
-
b
.
diggCount
,
},{
title
:
'
质量分
'
,
dataIndex
:
'
score
'
,
key
:
'
score
'
,
sorter
:
(
a
,
b
)
=>
a
.
score
-
b
.
score
,
},
{
title
:
'
发文时间
'
,
...
...
@@ -39,6 +35,5 @@ export const tableColumns= [
dataIndex
:
'
message
'
,
},
{
title
:
'
操作
'
,
key
:
'
option
'
,
fixed
:
true
key
:
'
option
'
}]
\ No newline at end of file
src/components/writeExcel.js
0 → 100644
浏览文件 @
0367277f
// 输出base64编码
const
base64
=
s
=>
window
.
btoa
(
unescape
(
encodeURIComponent
(
s
)));
const
tableToExcel
=
async
(
jsonData
)
=>
{
return
new
Promise
(
resolve
=>
{
try
{
console
.
log
(
'
start
'
,
jsonData
)
let
str
=
'
<tr>
'
Object
.
keys
(
jsonData
[
0
]).
forEach
(
name
=>
{
const
tdStr
=
`<tr>
${
name
}
</td>`
str
+=
tdStr
})
str
+=
'
</tr>
'
for
(
let
i
=
0
;
i
<
jsonData
.
length
;
i
++
)
{
str
+=
'
<tr>
'
;
for
(
const
key
in
jsonData
[
i
])
{
// 增加\t为了不让表格显示科学计数法或者其他格式
str
+=
`<td>
${
jsonData
[
i
][
key
]
+
'
\t
'
}
</td>`
;
}
str
+=
'
</tr>
'
;
}
// Worksheet名
const
worksheet
=
'
用户质量分
'
const
uri
=
'
data:application/vnd.ms-excel;base64,
'
;
// 下载的表格模板数据
const
template
=
`<html xmlns:o="urn:schemas-microsoft-com:office:office"
xmlns:x="urn:schemas-microsoft-com:office:excel"
xmlns="http://www.w3.org/TR/REC-html40">
<head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet>
<x:Name>
${
worksheet
}
</x:Name>
<x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet>
</x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]-->
<meta charset='utf-8' />
</head><body><table>
${
str
}
</table></body></html>`
;
console
.
log
(
'
str
'
,
str
)
// 下载模板
window
.
location
.
href
=
uri
+
base64
(
template
);
resolve
(
true
)
}
catch
(
r
)
{
console
.
log
(
r
,
'
r
'
)
resolve
(
false
)
}
})
};
export
async
function
exportExcel
(
tableData
)
{
return
new
Promise
(
async
(
resolve
)
=>
{
try
{
await
tableToExcel
(
tableData
)
resolve
(
true
)
}
catch
(
r
)
{
console
.
log
(
r
,
'
r
'
)
resolve
(
false
)
}
})
}
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录