|
@@ -5,7 +5,7 @@
|
|
|
<div class="title_center">新闻资讯</div>
|
|
|
<el-image class="image" :src="right" fit="fill" />
|
|
|
</div>
|
|
|
- <div class="one">
|
|
|
+ <div class="one" data-aos="fade-up" data-aos-duration="1000">
|
|
|
<div class="one_left">
|
|
|
<el-carousel height="680px">
|
|
|
<el-carousel-item v-for="(item, index) in carouselList" :key="index">
|
|
@@ -43,40 +43,38 @@
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
- <div class="title">
|
|
|
- <el-image class="image" :src="left" fit="fill" />
|
|
|
- <div class="title_center">数据展示</div>
|
|
|
- <el-image class="image" :src="right" fit="fill" />
|
|
|
- </div>
|
|
|
- <div class="two">
|
|
|
+ <div class="two" data-aos="fade-up" data-aos-duration="1000">
|
|
|
+ <div class="title">
|
|
|
+ <el-image class="image" :src="left" fit="fill" />
|
|
|
+ <div class="title_center">数据展示</div>
|
|
|
+ <el-image class="image" :src="right" fit="fill" />
|
|
|
+ </div>
|
|
|
<div class="two_1">
|
|
|
<div class="twoList" v-for="(item, index) in recordList" :key="index" @click="toSelect(item)">
|
|
|
<div class="two_num">
|
|
|
- <span>{{ item.num || 0 }}</span>
|
|
|
+ <span>{{ item.num || 0 }}+</span>
|
|
|
<span>{{ item.unit || '' }}</span>
|
|
|
</div>
|
|
|
<div class="two_title">{{ item.name || '暂无名称' }}</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="two_2">
|
|
|
- <div class="two_title">数据分析</div>
|
|
|
+ <div class="two_title">{{ recordInfo.name }}数据分析</div>
|
|
|
<div class="two_content">
|
|
|
- <div class="left">
|
|
|
- <cecharts1></cecharts1>
|
|
|
- </div>
|
|
|
- <div class="right">
|
|
|
- <cecharts2></cecharts2>
|
|
|
- </div>
|
|
|
+ <cecharts1 v-if="recordInfo.id == '1'"></cecharts1>
|
|
|
+ <secharts1 v-if="recordInfo.id == '2'"></secharts1>
|
|
|
+ <decharts1 v-if="recordInfo.id == '3'"></decharts1>
|
|
|
+ <pecharts1 v-if="recordInfo.id == '4'"></pecharts1>
|
|
|
+ <aecharts1 v-if="recordInfo.id == '5'"></aecharts1>
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
-
|
|
|
- <div class="title">
|
|
|
- <el-image class="image" :src="left" fit="fill" />
|
|
|
- <div class="title_center">成果展示</div>
|
|
|
- <el-image class="image" :src="right" fit="fill" />
|
|
|
- </div>
|
|
|
- <div class="thr">
|
|
|
+ <div class="thr" data-aos="fade-up" data-aos-duration="1000">
|
|
|
+ <div class="title">
|
|
|
+ <el-image class="image" :src="left" fit="fill" />
|
|
|
+ <div class="title_center">成果展示</div>
|
|
|
+ <el-image class="image" :src="right" fit="fill" />
|
|
|
+ </div>
|
|
|
<div class="more">
|
|
|
<div class="more_title" @click="toMore(2)">查看更多</div>
|
|
|
</div>
|
|
@@ -94,12 +92,12 @@
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
- <div class="title">
|
|
|
- <el-image class="image" :src="left" fit="fill" />
|
|
|
- <div class="title_center">孵化体系</div>
|
|
|
- <el-image class="image" :src="right" fit="fill" />
|
|
|
- </div>
|
|
|
- <div class="four">
|
|
|
+ <div class="four" data-aos="fade-up" data-aos-duration="1000">
|
|
|
+ <div class="title">
|
|
|
+ <el-image class="image" :src="left" fit="fill" />
|
|
|
+ <div class="title_center">孵化体系</div>
|
|
|
+ <el-image class="image" :src="right" fit="fill" />
|
|
|
+ </div>
|
|
|
<div class="more">
|
|
|
<div class="more_title" @click="toMore(1)">查看更多</div>
|
|
|
</div>
|
|
@@ -161,6 +159,7 @@
|
|
|
<script setup>
|
|
|
import moment from 'moment'
|
|
|
import { get } from 'lodash-es'
|
|
|
+import { useNumberAnimation } from '@/utils/animation'
|
|
|
// 图片引入
|
|
|
import left from '/images/top-left.png'
|
|
|
import right from '/images/top-right.png'
|
|
@@ -168,8 +167,11 @@ import new_4 from '/images/new_4.png'
|
|
|
import friend from '/images/friend.jpeg'
|
|
|
import baseLogo from '/images/base.jpg'
|
|
|
// 组件
|
|
|
-import cecharts1 from './parts/company/echarts1.vue'
|
|
|
-import cecharts2 from './parts/company/echarts2.vue'
|
|
|
+import cecharts1 from './parts/echarts1.vue'
|
|
|
+import secharts1 from './parts/echarts2.vue'
|
|
|
+import decharts1 from './parts/echarts3.vue'
|
|
|
+import pecharts1 from './parts/echarts4.vue'
|
|
|
+import aecharts1 from './parts/echarts5.vue'
|
|
|
// 用户信息
|
|
|
import { UserStore } from '@/store/user'
|
|
|
const userStore = UserStore()
|
|
@@ -187,11 +189,12 @@ const props = defineProps({
|
|
|
list: { type: Array, default: () => [] }
|
|
|
})
|
|
|
|
|
|
-const { carouselList, incubatorList } = toRefs(props)
|
|
|
+const { carouselList, incubatorList, recordList } = toRefs(props)
|
|
|
|
|
|
const emits = defineEmits(['toActive'])
|
|
|
|
|
|
const active = ref('0')
|
|
|
+const recordInfo = ref({})
|
|
|
const newList = ref([
|
|
|
{ value: '0', label: '政策信息' },
|
|
|
{ value: '1', label: '新闻通知' },
|
|
@@ -254,12 +257,38 @@ const handleMousOut = (index) => {
|
|
|
}
|
|
|
// 选择数据分析
|
|
|
const toSelect = (item) => {
|
|
|
- console.log(item)
|
|
|
+ recordInfo.value = item
|
|
|
}
|
|
|
-// 点击echarts
|
|
|
-const dataChange = (item) => {
|
|
|
- console.log(item)
|
|
|
+// 请求
|
|
|
+onMounted(() => {
|
|
|
+ setTimeout(async () => {
|
|
|
+ await Animation()
|
|
|
+ }, 2000)
|
|
|
+})
|
|
|
+// 选择数据分析
|
|
|
+const Animation = () => {
|
|
|
+ if (recordList.value && recordList.value.length > 0) {
|
|
|
+ for (const val of recordList.value) {
|
|
|
+ useNumberAnimation({
|
|
|
+ from: 0,
|
|
|
+ to: val.num,
|
|
|
+ duration: 3000,
|
|
|
+ onProgress: (v) => {
|
|
|
+ if (v) val.num = v.toFixed(0)
|
|
|
+ }
|
|
|
+ })
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
+watch(
|
|
|
+ recordList,
|
|
|
+ (item) => {
|
|
|
+ recordInfo.value = item[0]
|
|
|
+ },
|
|
|
+ {
|
|
|
+ deep: true
|
|
|
+ }
|
|
|
+)
|
|
|
</script>
|
|
|
<style scoped lang="scss">
|
|
|
.page {
|
|
@@ -420,18 +449,15 @@ const dataChange = (item) => {
|
|
|
color: #323232;
|
|
|
}
|
|
|
.two_content {
|
|
|
- display: flex;
|
|
|
- justify-content: space-between;
|
|
|
- .left {
|
|
|
- width: 50%;
|
|
|
- }
|
|
|
- .right {
|
|
|
- width: 50%;
|
|
|
- }
|
|
|
+ margin: 20px 0 0 0;
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
.thr {
|
|
|
+ background: #f1f6f9;
|
|
|
+ background-image: url(/images/con1-bg.png);
|
|
|
+ background-size: 100% 100%;
|
|
|
+ padding: 10px 0 0 0;
|
|
|
.more {
|
|
|
max-width: 1700px;
|
|
|
margin: 0 auto 10px;
|
|
@@ -450,10 +476,7 @@ const dataChange = (item) => {
|
|
|
}
|
|
|
}
|
|
|
.thr_1 {
|
|
|
- background: #f1f6f9;
|
|
|
- background-image: url(/images/con1-bg.png);
|
|
|
- background-size: 100% 100%;
|
|
|
- padding: 30px 0 10px;
|
|
|
+ padding: 10px 0 10px;
|
|
|
.w_1700 {
|
|
|
max-width: 1700px;
|
|
|
margin: 0 auto;
|