From 5f4c128cd325cfea43bd38de5cef2d9170be7472 Mon Sep 17 00:00:00 2001
From: zhongshujie <2862698242@qq.com>
Date: 星期二, 08 四月 2025 17:53:58 +0800
Subject: [PATCH] 样式调整

---
 src/views/directory/index.vue |  553 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 550 insertions(+), 3 deletions(-)

diff --git a/src/views/directory/index.vue b/src/views/directory/index.vue
index e9f4253..5f2f359 100644
--- a/src/views/directory/index.vue
+++ b/src/views/directory/index.vue
@@ -1,9 +1,556 @@
 <template>
-  <div>瀛︾敓鍚嶅綍</div>
+  <div class="page">
+    <div class="page-header">
+      <p>鐜嬫案鐐庨櫌澹鐢熺洰褰�</p>
+    </div>
+    <div class="page-main-father">
+      <div class="page-main-title">
+        <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="[activeTabs == 'list' ? listIcon : noListIcon]" alt="" />
+          <span>鍒楄〃鏄剧ず</span>
+        </p>
+      </div>
+      <!-- 鍥捐〃鏄剧ず -->
+      <div class="charts-main" v-if="activeTabs == 'chart'">
+        <div class="radial-tree-container">
+          <div ref="chart" style="width: 100%; height: 600px"></div>
+        </div>
+      </div>
+      <!-- 鍒楄〃鏄剧ず -->
+      <div class="page-main" v-if="activeTabs == 'list'">
+        <div v-for="(item, index) in universityList" :key="index">
+          <div
+            class="table-title"
+            v-if="item.studentList && item.studentList.length > 0"
+          >
+            <div class="table-title-left">
+              <p class="table-title-name">{{ item.name }}</p>
+              <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="[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>
+            </tr>
+            <tr v-for="(citem, cindex) in item.studentList" :key="cindex">
+              <td>
+                {{ citem.studentName }}
+              </td>
+              <td>
+                {{ citem.gender }}
+              </td>
+              <td>{{ citem.studyTime }}</td>
+              <td>{{ citem.workUnit }}</td>
+              <td>{{ citem.position }}</td>
+              <td>{{ citem.title }}</td>
+            </tr>
+          </table>
+        </div>
+      </div>
+    </div>
+  </div>
 </template>
 
 <script>
-export default {};
+import * as echarts from "echarts";
+import axios from "axios";
+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: "鍖椾含涓尰鑽ぇ瀛�",
+          degree: "纭曞+",
+          isShow: "true",
+          studentList: [
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+          ],
+        },
+        {
+          name: "鍖椾含涓尰鑽ぇ瀛�",
+          degree: "纭曞+",
+          isShow: "true",
+          studentList: [
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+          ],
+        },
+        {
+          name: "鍖椾含涓尰鑽ぇ瀛�",
+          degree: "纭曞+",
+          isShow: "true",
+          studentList: [
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+          ],
+        },
+        {
+          name: "鍖椾含涓尰鑽ぇ瀛�",
+          degree: "纭曞+",
+          isShow: "true",
+          studentList: [],
+        },
+        {
+          name: "鍖椾含涓尰鑽ぇ瀛�",
+          degree: "纭曞+",
+          isShow: "true",
+          studentList: [
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+          ],
+        },
+        {
+          name: "鍖椾含涓尰鑽ぇ瀛�",
+          degree: "纭曞+",
+          isShow: "true",
+          studentList: [],
+        },
+        {
+          name: "鍖椾含涓尰鑽ぇ瀛�",
+          degree: "纭曞+",
+          isShow: "true",
+          studentList: [
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+            {
+              studentName: "鐜嬬帀鏉�",
+              gender: "鐢�",
+              studyTime: "1985.09-1988.07",
+              workUnit: "鍖椾含涓尰鑽ぇ瀛︿笢鏂瑰闄�",
+              position: "鍘熼櫌闀�",
+              title: "涓讳换鍖诲笀銆佹暀鎺�",
+            },
+          ],
+        },
+      ],
+      chart: null,
+      chartData: {
+        name: "Root",
+        children: [
+          {
+            name: "鐜嬬帀鏉�",
+            children: [
+              { name: "Leaf 1-1" },
+              { name: "Leaf 1-2" },
+              { name: "Leaf 1-3" },
+            ],
+          },
+          {
+            name: "Node 2",
+            children: [
+              {
+                name: "Node 2-1",
+                children: [{ name: "Leaf 2-1-1" }, { name: "Leaf 2-1-2" }],
+              },
+              { name: "Leaf 2-2" },
+            ],
+          },
+          {
+            name: "Node 3",
+            children: [{ name: "Leaf 3-1" }, { name: "Leaf 3-2" }],
+          },
+        ],
+      },
+    };
+  },
+
+  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;
+      console.log(this.activeTabs, "activeTabs");
+      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",
+          formatter: (params) => {
+            const data = params.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>
+                
+              </div>
+            `;
+          },
+        },
+        series: [
+          {
+            type: "tree",
+            data: [this.chartData],
+            layout: "radial",
+            symbol: "emptyCircle",
+            symbolSize: 7,
+            initialTreeDepth: -1, // 灞曞紑鎵�鏈夎妭鐐�
+            animationDurationUpdate: 750,
+            emphasis: {
+              focus: "descendant",
+            },
+            label: {
+              position: "left",
+              verticalAlign: "middle",
+              align: "right",
+              fontSize: 12,
+              rotate: 0,
+            },
+            leaves: {
+              label: {
+                position: "right",
+                verticalAlign: "middle",
+                align: "left",
+              },
+            },
+            expandAndCollapse: true,
+            lineStyle: {
+              color: "#ccc",
+              width: 1,
+            },
+            itemStyle: {
+              color: "#4f8ff7",
+              borderColor: "#4f8ff7",
+            },
+            roam: true,
+            center: ["10%", "15%"], // 寰皟鍨傜洿灞呬腑
+            radius: "60%", // 澧炲ぇ鍗婂緞鍗犳瘮
+            nodePadding: 20,
+          },
+        ],
+      };
+
+      this.chart.setOption(option);
+    },
+    handleResize() {
+      if (this.chart) {
+        this.chart.resize();
+      }
+    },
+  },
+};
 </script>
 
-<style></style>
+<style lang="less" scoped>
+.page {
+  width: 100%;
+  height: 100%;
+  box-sizing: border-box;
+  background-color: #e9e1d4;
+  position: relative;
+}
+
+.page-header {
+  height: 9.4%;
+  width: 100%;
+  text-align: left;
+  border-bottom: 2px solid #937950;
+  background-color: #e9e1d4;
+  position: sticky;
+  top: 0;
+  z-index: 100;
+  p {
+    padding: 2% 0 1.9% 0;
+    font-family: Alimama DongFangDaKai;
+    font-size: 30px;
+    text-indent: 1em;
+    border-bottom: 1px solid #937950;
+  }
+}
+
+.page-main-father {
+  height: calc(100% - 9.4%);
+  width: 100%;
+  overflow: auto;
+}
+
+.page-main-title {
+  display: flex;
+  align-items: center;
+  justify-content: center;
+  cursor: pointer;
+  margin-bottom: 75px;
+  color: #9e9e9e;
+  margin-top: 1%;
+
+  p {
+    display: flex;
+    align-items: center;
+    padding: 15.5px 20px;
+    border-bottom: 2px solid #9e9e9e;
+  }
+
+  img {
+    width: 24px;
+    height: auto;
+    margin-right: 10px;
+  }
+
+  span {
+    font-family: Source Han Sans;
+    font-size: 24px;
+    font-weight: bold;
+  }
+}
+
+.active-tab {
+  color: #937950 !important;
+  border-bottom: 2px solid #937950 !important;
+}
+
+.page-main {
+  width: 77.3%;
+  margin: 0 auto;
+  overflow: hidden;
+  margin-bottom: 100px;
+
+  table {
+    width: 100%;
+    border-collapse: collapse;
+  }
+
+  tr {
+    background-color: #fff;
+    background-clip: padding-box;
+    border-bottom: 2px solid transparent;
+  }
+
+  th {
+    font-family: Source Han Serif CN;
+    font-size: 14px;
+    font-weight: bold;
+    padding: 4px 41px;
+  }
+
+  td {
+    font-family: Source Han Serif CN;
+    font-size: 14px;
+    padding: 6px 41px;
+    text-align: center;
+  }
+
+  tr:last-child td {
+    border-bottom: none;
+    /* 绉婚櫎鏈�鍚庝竴琛岀殑涓嬭竟妗� */
+  }
+}
+
+.charts-main {
+  // background-color: #000;
+}
+
+.table-title {
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  padding: 10px 28px;
+  background-color: #d8cbb6;
+  margin-bottom: 4px;
+  margin-top: 2px;
+
+  .table-title-left {
+    display: flex;
+    align-items: center;
+  }
+
+  .table-title-name {
+    width: 200px;
+    overflow: hidden;
+    font-family: Source Han Serif CN;
+    font-size: 18px;
+    font-weight: bold;
+  }
+
+  .table-title-degree {
+    font-family: Source Han Serif CN;
+    font-size: 14px;
+    font-weight: bold;
+    margin-right: 40px;
+  }
+
+  .table-title-number {
+    font-family: Source Han Serif CN;
+    font-size: 14px;
+    font-weight: bold;
+  }
+
+  .table-title-right {
+    cursor: pointer;
+  }
+
+  img {
+    width: 20px;
+    height: auto;
+  }
+}
+</style>

--
Gitblit v1.9.1