From fc43cbb086dcd7a5e8976d67d3e6e0f29f9e26ad Mon Sep 17 00:00:00 2001 From: 杨磊 <505174330@qq.com> Date: 星期二, 08 四月 2025 14:51:47 +0800 Subject: [PATCH] Merge branch 'master' of http://182.92.203.7:2001/r/wyyDatabase --- src/views/directory/index.vue | 353 +++++++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 263 insertions(+), 90 deletions(-) diff --git a/src/views/directory/index.vue b/src/views/directory/index.vue index e3f9a49..9ff6048 100644 --- a/src/views/directory/index.vue +++ b/src/views/directory/index.vue @@ -4,77 +4,109 @@ <p>鐜嬫案鐐庨櫌澹鐢熺洰褰�</p> </div> <div class="page-main-title"> - <p @click="changeTab('chart')" :class="[activeTabs == 'chart' ? 'active-tab' : '']"> - <img src="../../assets/images/directory/chartIcon.png" alt=""> + <p + @click="changeTab('chart')" + :class="[activeTabs == 'chart' ? 'active-tab' : '']" + > + <img :src="[activeTabs == 'chart' ? chartIcon : noChartIcon]" alt="" /> <span>鍥捐〃鏄剧ず</span> </p> - <p @click="changeTab('list')" :class="[activeTabs == 'list' ? 'active-tab' : '']"> - <img src="../../assets/images/directory/listIcon.png" alt=""> + <p + @click="changeTab('list')" + :class="[activeTabs == 'list' ? 'active-tab' : '']" + > + <img :src="[activeTabs == 'list' ? listIcon : noListIcon]" alt="" /> <span>鍒楄〃鏄剧ず</span> </p> </div> <!-- 鍥捐〃鏄剧ず --> <div class="charts-main" v-if="activeTabs == 'chart'"> - <!-- <div class="pageBox"> - <div class="main" v-loading="loading" element-loading-text="鍔犺浇涓�..." - element-loading-background="rgba(255,255,255,.5)"> - <div class="main-content"> - <div class="detailBox"> - <div class="legendBox"> - <div class="legendItem"> - <div class="lengend-color"></div> - <div class="lengend-text">鐢�</div> + <div class="radial-tree-container"> + <div ref="chart" style="width: 100%; height: 600px"></div> + </div> + <transition name="el-fade-in-linear"> + <div class="tooltipBox" v-show="tooltipShow"> + <div + style=" + padding: 10px; + background: #fdf8f0; + border-radius: 5px; + width: 100%; + max-height: 500px; + text-align: center; + " + > + <div style="display: flex"> + <div + style=" + width: 80px; + height: 80px; + position: relative; + margin-bottom: 10px; + background: #d8d8d8; + " + > + <img + class="autoImg" + src="@/assets/images/directory/touxiang.png" + alt="" + /> + </div> + <div + style="padding-top: 20px; text-align: left; margin-left: 20px" + > + <div + style="font-size: 16px; font-weight: bold; margin-bottom: 5px" + > + {{ currentNodeInfo.name }} </div> - <div class="legendItem"> - <div class="lengend-color"></div> - <div class="lengend-text">鏃�</div> - </div> - <div class="legendItem"> - <div class="lengend-color"></div> - <div class="lengend-text">鍑�</div> - </div> - <div class="legendItem"> - <div class="lengend-color"></div> - <div class="lengend-text">鏈�</div> - </div> - <div class="legendItem"> - <div class="lengend-color"></div> - <div class="lengend-text">涓�</div> - </div> - <div class="legendItem"> - <div class="lengend-color"></div> - <div class="lengend-text">鏈煡</div> + <div style="margin-top: 20px"> + <span> 鐢� </span> <span> 纭曞+ </span> + <span> 鍖椾含涓尰鑽ぇ瀛� </span> </div> </div> - <div class="echartsBox"> - <div class="clickBox" id="clickBox"> - <div class="clickBoxContent"> - <div class="imgBox" style="width: 300px; height: 150px"> - <img :src="detailData.img" /> - </div> - <div class="title">{{ detailData.title }}</div> - <div class="subTitle">{{ detailData.subTitle }}</div> - <div class="desc">{{ detailData.desc }}</div> - <div class="btnBox"> - <div @click="gotoDetail()" class="detailBtn">浜嗚В鏇村</div> - <img class="closeBtn" @click.stop="closeDetail()" - src="@/assets/images/chronology/icon_close.svg" /> - </div> - </div> - </div> - <div class="echarts" style="width: 100%; height: 100%"></div> + </div> + + <div + style=" + font-size: 16px; + font-weight: bold; + margin-bottom: 5px; + text-align: left; + margin-top: 10px; + " + > + <p style="margin-bottom: 15px">瀛︿範鏃堕棿锛�1985.09 -1988.07</p> + <p style="margin-bottom: 15px"> + 鐜板伐浣滃崟浣嶏細鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰尰闄� + </p> + <p style="margin-bottom: 15px">鑱屽姟锛氬師闄㈤暱</p> + <p style="margin-bottom: 15px">鑱岀О锛氫富浠诲尰甯堛�佹暀鎺�</p> + </div> + <div style="text-align: left; line-height: 22px"> + <p> + 澶у鸡鍢堝槇濡傛�ラ洦锛屽皬寮﹀垏鍒囧绉佽銆傚槇鍢堝垏鍒囬敊鏉傚脊锛屽ぇ鐝犲皬鐝犺惤鐜夌洏銆傞棿鍏宠幒璇姳搴曟粦锛屽菇鍜芥硥娴佸啺涓嬮毦銆傚啺娉夊喎娑╁鸡鍑濈粷锛屽嚌缁濅笉閫氬0鏆傛瓏銆傚埆鏈夊菇鎰佹殫鎭ㄧ敓锛屾鏃舵棤澹拌儨鏈夊0銆傞摱鐡朵箥鐮存按娴嗚扛锛岄搧楠戠獊鍑哄垁鏋福銆傛洸缁堟敹鎷ㄥ綋蹇冪敾锛屽洓寮︿竴澹板瑁傚笡銆備笢鑸硅タ鑸倓鏃犺█锛屽敮瑙佹睙蹇冪鏈堢櫧銆� + </p> + </div> + <div + style=" + display: flex; + justify-content: space-between; + margin-top: 20px; + " + > + <div style="text-align: left; width: 48%; line-height: 22px"> + <p> + 瑙傚か鏄庡爞涔嬪畯澹篃锛屽垯绐佸厐鐬虫洦锛屼箥鏄庝箥钂欙紝鑻ュぇ鍙ゅ厓姘斾箣缁撶┖銆傚穬宓搁娌擄紝鑻ュ惮鑻ュ丢锛屼技澶╅槂鍦伴棬涔嬪紑闃栥�傚皵涔冨垝宀濆硥浠ュ渤绔嬶紝閮佺┕宕囪�岄缚绾枫�傚啝鐧剧帇鑰屽瀭鍕嬶紝鐑涗竾璞¤�岃吘鏂囥�傜獧鎯氭亶浠ユ礊鍚紝鍛煎祵宀╄�屽倣鍒嗐�傚張姣斾箮鏄嗗北涔嬪ぉ鏌憋紝鐭椾節闇勮�屽瀭浜戙�� + </p> </div> - <div class="toponymBox"> - <div class="imgBox" style="width: 280px; height: 280px"> - <img :src="toponymData.img" /> - </div> - <div class="">鎴忛櫌锛歿{ toponymData.toponymName || "-" }}</div> - <div class="">鍐滃巻锛歿{ toponymData.chineseTime || "-" }}</div> + <div> + <img src="@/assets/images/directory/test.png" alt="" /> </div> </div> </div> </div> - </div> --> + </transition> </div> <!-- 鍒楄〃鏄剧ず --> <div class="page-main" v-if="activeTabs == 'list'"> @@ -85,17 +117,14 @@ <p class="table-title-degree">{{ item.degree }}</p> <p class="table-title-number">{{ item.studentList.length }}浜�</p> </div> - <div class="table-title-right" @click="item.isShow = !item.isShow"><img - src="../../assets/images/directory/topIcon.png" alt=""></div> + <div class="table-title-right" @click="item.isShow = !item.isShow"> + <img :src="[item.isShow ? topIcon : bottomIcon]" alt="" /> + </div> </div> <table cellpadding="100" v-if="item.studentList && item.studentList.length > 0 && item.isShow"> <tr class="table-heading"> - <th> - 濮撳悕 - </th> - <th> - 鎬у埆 - </th> + <th>濮撳悕</th> + <th>鎬у埆</th> <th>瀛︿範鏃堕棿</th> <th>宸ヤ綔鍗曚綅锛堝埌浜岀骇鍗曚綅鍏ㄧО锛�</th> <th>鑱屽姟</th> @@ -120,11 +149,22 @@ </template> <script> -import echarts from "@/assets/js/echarts.min.js"; +import * as echarts from "echarts"; +import axios from "axios"; + +import debounce from "lodash/debounce"; +import treeData from "./treeData.json"; export default { data() { return { + chartIcon: require("@/assets/images/directory/chartIcon.png"), + noChartIcon: require("@/assets/images/directory/noChartIcon.png"), + listIcon: require("@/assets/images/directory/listIcon.png"), + noListIcon: require("@/assets/images/directory/noListIcon.png"), + topIcon: require("@/assets/images/directory/topIcon.png"), + bottomIcon: require("@/assets/images/directory/bottomIcon.png"), activeTabs: "chart", + universityList: [ { name: "鍖椾含涓尰鑽ぇ瀛�", @@ -155,7 +195,7 @@ position: "鍘熼櫌闀�", title: "涓讳换鍖诲笀銆佹暀鎺�", }, - ] + ], }, { name: "鍖椾含涓尰鑽ぇ瀛�", @@ -186,7 +226,7 @@ position: "鍘熼櫌闀�", title: "涓讳换鍖诲笀銆佹暀鎺�", }, - ] + ], }, { name: "鍖椾含涓尰鑽ぇ瀛�", @@ -217,14 +257,13 @@ position: "鍘熼櫌闀�", title: "涓讳换鍖诲笀銆佹暀鎺�", }, - ] + ], }, { name: "鍖椾含涓尰鑽ぇ瀛�", degree: "纭曞+", isShow: "true", - studentList: [ - ] + studentList: [], }, { name: "鍖椾含涓尰鑽ぇ瀛�", @@ -255,14 +294,13 @@ position: "鍘熼櫌闀�", title: "涓讳换鍖诲笀銆佹暀鎺�", }, - ] + ], }, { name: "鍖椾含涓尰鑽ぇ瀛�", degree: "纭曞+", isShow: "true", - studentList: [ - ] + studentList: [], }, { name: "鍖椾含涓尰鑽ぇ瀛�", @@ -293,23 +331,150 @@ position: "鍘熼櫌闀�", title: "涓讳换鍖诲笀銆佹暀鎺�", }, - ] + ], }, - ] - } + ], + chart: null, + chartData: treeData, + currentNodeInfo: {}, + tooltipShow: false, + }; }, + mounted() { + this.initChart(); + window.addEventListener("resize", this.handleResize); + }, + beforeDestroy() { + window.removeEventListener("resize", this.handleResize); + if (this.chart) { + this.chart.dispose(); + } + }, methods: { changeTab(key) { - this.activeTabs = key + this.activeTabs = key; console.log(this.activeTabs, "activeTabs"); - // if (key == "chart") { + if (key == "chart") { + this.$nextTick(() => { + this.initChart(); + window.addEventListener("resize", this.handleResize); + }); + } + }, + initChart() { + this.chart = echarts.init(this.$refs.chart); + const option = { + tooltip: { + trigger: "item", + triggerOn: "mousemove", + backgroundColor: "#FDF8F0", + formatter: (params) => { + const data = params.data; + this.currentNodeInfo = data; + return ` + <div style=" + padding: 10px; + background: #FDF8F0; + border-radius: 5px; + max-width: 300px; + width: 360px; + text-align: center; + "> + <div style="width: 80px;height: 80px;position: relative; margin: 0 auto; margin-bottom: 10px;background: #D8D8D8;"> + <img class="autoImg" src="${require("@/assets/images/directory/touxiang.png")}" alt=""> + </div> + <div style="font-size: 16px; font-weight: bold; margin-bottom: 5px;">${ + data.name + }</div> + <div> <span> 鐢� </span> <span> 纭曞+ </span> <span> 鍖椾含涓尰鑽ぇ瀛� </span></div> + <div style="font-size: 16px; font-weight: bold; margin-bottom: 5px;text-align: left;margin-top: 10px;"> + <p style="margin-bottom: 5px;">瀛︿範鏃堕棿锛�1985.09 -1988.07</p> + <p style="margin-bottom: 5px;">鐜板伐浣滃崟浣嶏細鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰尰闄�</p> + <p style="margin-bottom: 5px;">鑱屽姟锛氬師闄㈤暱</p> + <p style="margin-bottom: 5px;">鑱岀О锛氫富浠诲尰甯堛�佹暀鎺�</p> + </div> - // } else if (key == 'list') { + </div> + `; + }, + }, + textStyle: { + color: "#bc1c00" // 璁剧疆鏁翠綋瀛椾綋棰滆壊涓虹孩鑹� + }, + edgeLabel: { + normal: { + color: "#bc1c00" // 璁剧疆绾挎潯鐨勯鑹蹭负绾㈣壊 + } + }, + series: [ + { + type: "tree", + data: [this.chartData], + // symbol: "emptyCircle", + top: "10%", + bottom: "10%", + layout: "radial", + symbol: "emptyCircle", + symbolSize: 7, + initialTreeDepth: 3, // 灞曞紑鎵�鏈夎妭鐐� + animationDurationUpdate: 750, + emphasis: { + focus: "descendant", + }, + label: { + position: "top", //鏍囩鐨勪綅缃�� + verticalAlign: "middle", //鏂囧瓧鍨傜洿瀵归綈鏂瑰紡锛岄粯璁よ嚜鍔ㄣ�� + fontSize: 12, //鏂囧瓧鐨勫瓧浣撳ぇ灏� + color: "#bc1c00", + }, + leaves: { + symbol: "emptyCircle", + label: { + fontSize: 12, + }, + }, + expandAndCollapse: false, + lineStyle: { + color: "#bc1c00", + width: 1, + }, + itemStyle: { + symbol: "emptyCircle", + color: "#bc1c00", + }, + roam: true, + center: ["5%", "0%"], // 寰皟鍨傜洿灞呬腑 + radius: "100%", // 澧炲ぇ鍗婂緞鍗犳瘮 + nodePadding: 120, + }, + ], + }; - // } - } - } + this.chart.setOption(option); + + this.chart.on( + "showTip", + debounce((event) => { + console.log("鏄剧ず鏃剁殑鍥炶皟", event); + this.tooltipShow = true; + }, 500) + ); + + this.chart.on( + "hideTip", + debounce((event) => { + console.log("闅愯棌鏃剁殑鍥炶皟", event); + this.tooltipShow = false; + }, 500) + ); + }, + handleResize() { + if (this.chart) { + this.chart.resize(); + } + }, + }, }; </script> @@ -344,13 +509,13 @@ justify-content: center; cursor: pointer; margin-bottom: 75px; - color: #9E9E9E; + color: #9e9e9e; p { display: flex; align-items: center; padding: 15.5px 20px; - border-bottom: 2px solid #9E9E9E; + border-bottom: 2px solid #9e9e9e; } img { @@ -370,8 +535,6 @@ color: #937950 !important; border-bottom: 2px solid #937950 !important; } - - .page-main { width: 1313px; @@ -410,15 +573,19 @@ } } +.charts-main { + // background-color: #000; + position: relative; +} + .table-title { display: flex; align-items: center; justify-content: space-between; padding: 10px 28px; - background-color: #D8CBB6; + background-color: #d8cbb6; margin-bottom: 4px; margin-top: 2px; - .table-title-left { display: flex; @@ -446,7 +613,6 @@ font-weight: bold; } - .table-title-right { cursor: pointer; } @@ -455,6 +621,13 @@ width: 20px; height: auto; } - +} +.tooltipBox { + max-height: 500px; + max-width: 500px; + background-color: #fdf8f0; + position: absolute; + bottom: -60px; + right: 40px; } </style> -- Gitblit v1.9.1