mirror of
https://github.com/iczer/vue-antd-admin
synced 2025-04-05 19:41:37 +08:00
新增tab图表
This commit is contained in:
parent
5ea08d91bb
commit
94a8a66759
@ -1,4 +1,5 @@
|
|||||||
# vue-antd-admin
|
# vue-antd-admin
|
||||||
Ant Design Pro 的 Vue 实现(非官方)
|
**Ant Design Pro 的 Vue 实现(非官方)**
|
||||||
|
一个开箱即用的中后台前端/设计解决方案
|
||||||
|
|
||||||
[预览地址](https://iczer.github.io)
|
[预览地址](https://iczer.github.io)(开发中...)
|
||||||
|
53
src/components/chart/Bar.vue
Normal file
53
src/components/chart/Bar.vue
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
<template>
|
||||||
|
<div >
|
||||||
|
<h4>{{title}}</h4>
|
||||||
|
<v-chart :force-fit="true" height="251" :data="data">
|
||||||
|
<v-tooltip />
|
||||||
|
<v-axis />
|
||||||
|
<v-bar position="x*y"/>
|
||||||
|
</v-chart>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
|
||||||
|
const data = []
|
||||||
|
for (let i = 0; i < 12; i += 1) {
|
||||||
|
data.push({
|
||||||
|
x: `${i + 1}月`,
|
||||||
|
y: Math.floor(Math.random() * 1000) + 200
|
||||||
|
})
|
||||||
|
}
|
||||||
|
const tooltip = [
|
||||||
|
'x*y',
|
||||||
|
(x, y) => ({
|
||||||
|
name: x,
|
||||||
|
value: y
|
||||||
|
})
|
||||||
|
]
|
||||||
|
|
||||||
|
const scale = [{
|
||||||
|
dataKey: 'x',
|
||||||
|
min: 2
|
||||||
|
}, {
|
||||||
|
dataKey: 'y',
|
||||||
|
title: '时间',
|
||||||
|
min: 1,
|
||||||
|
max: 22
|
||||||
|
}]
|
||||||
|
export default {
|
||||||
|
name: 'Bar',
|
||||||
|
props: ['title'],
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
data,
|
||||||
|
scale,
|
||||||
|
tooltip
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
|
||||||
|
</style>
|
@ -51,10 +51,43 @@
|
|||||||
<div>
|
<div>
|
||||||
<mini-progress target="90" percent="78" color="#13C2C2" height="8px"/>
|
<mini-progress target="90" percent="78" color="#13C2C2" height="8px"/>
|
||||||
</div>
|
</div>
|
||||||
<div slot="footer">日均销售额 <span>¥ 234.56</span></div>
|
<div slot="footer">日均销售额 <span>¥ 234.56</span></div>
|
||||||
</chart-card>
|
</chart-card>
|
||||||
</a-col>
|
</a-col>
|
||||||
</a-row>
|
</a-row>
|
||||||
|
<a-card :bordered="false" :body-style="{padding: '24px'}">
|
||||||
|
<div class="salesCard">
|
||||||
|
<a-tabs default-active-key="1" size="large" :tab-bar-style="{marginBottom: '24px', paddingLeft: '16px'}">
|
||||||
|
<div class="extra-wrap" slot="tabBarExtraContent">
|
||||||
|
<div class="extra-item">
|
||||||
|
<a>今日</a>
|
||||||
|
<a>本周</a>
|
||||||
|
<a>本月</a>
|
||||||
|
<a>本年</a>
|
||||||
|
</div>
|
||||||
|
<a-range-picker :style="{width: '256px'}"></a-range-picker>
|
||||||
|
</div>
|
||||||
|
<a-tab-pane loading="true" tab="销售额" key="1">
|
||||||
|
<a-row>
|
||||||
|
<a-col :xl="16" :lg="12" :md="12" :sm="24" :xs="24">
|
||||||
|
<bar title="销售额趋势" />
|
||||||
|
</a-col>
|
||||||
|
<a-col :xl="8" :lg="12" :md="12" :sm="24" :xs="24">
|
||||||
|
123
|
||||||
|
</a-col>
|
||||||
|
</a-row>
|
||||||
|
</a-tab-pane>
|
||||||
|
<a-tab-pane tab="访问量" key="2"><a-row>
|
||||||
|
<a-col :xl="16" :lg="12" :md="12" :sm="24" :xs="24">
|
||||||
|
<bar title="销售额趋势" />
|
||||||
|
</a-col>
|
||||||
|
<a-col :xl="8" :lg="12" :md="12" :sm="24" :xs="24">
|
||||||
|
123
|
||||||
|
</a-col>
|
||||||
|
</a-row></a-tab-pane>
|
||||||
|
</a-tabs>
|
||||||
|
</div>
|
||||||
|
</a-card>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -68,12 +101,40 @@ import AIcon from 'vue-antd-ui/es/icon/icon'
|
|||||||
import MiniArea from '../chart/MiniArea'
|
import MiniArea from '../chart/MiniArea'
|
||||||
import MiniBar from '../chart/MiniBar'
|
import MiniBar from '../chart/MiniBar'
|
||||||
import MiniProgress from '../chart/MiniProgress'
|
import MiniProgress from '../chart/MiniProgress'
|
||||||
|
import ATabs from 'vue-antd-ui/es/tabs'
|
||||||
|
import ADatePicker from 'vue-antd-ui/es/date-picker'
|
||||||
|
import Bar from "../chart/Bar";
|
||||||
|
|
||||||
|
const ATabPane = ATabs.TabPane
|
||||||
|
const ARangePicker = ADatePicker.RangePicker
|
||||||
export default {
|
export default {
|
||||||
name: 'dashboard',
|
name: 'dashboard',
|
||||||
components: {MiniProgress, MiniBar, MiniArea, AIcon, ATooltip, ChartCard, ACard, ARow, ACol}
|
components: {
|
||||||
|
Bar,
|
||||||
|
ARangePicker,
|
||||||
|
ATabPane,
|
||||||
|
ATabs,
|
||||||
|
MiniProgress,
|
||||||
|
MiniBar,
|
||||||
|
MiniArea,
|
||||||
|
AIcon,
|
||||||
|
ATooltip,
|
||||||
|
ChartCard,
|
||||||
|
ACard,
|
||||||
|
ARow,
|
||||||
|
ACol}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped>
|
<style lang="less" scoped>
|
||||||
|
.extra-wrap{
|
||||||
|
|
||||||
|
}
|
||||||
|
.extra-item{
|
||||||
|
display: inline-block;
|
||||||
|
margin-right: 24px;
|
||||||
|
a{
|
||||||
|
margin-left: 24px;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user