feat(student): 添加学生详情页及相关路由和跳转按钮
- 在 class.vue 中增加“详情”按钮,可跳转至对应学生详情页 - 使用 vue-router 的 useRouter 实现页面跳转功能 - 添加 /student/:id 路由,绑定学生详情组件 student.vue - 新增 student.vue 组件,展示学生详细信息 - 精简 Header.vue, 移除多余导航链接,优化界面展示
This commit is contained in:
@@ -51,18 +51,6 @@
|
|||||||
学案
|
学案
|
||||||
</router-link>
|
</router-link>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
|
||||||
<a href="#"
|
|
||||||
class="block py-2 pr-4 pl-3 text-gray-700 border-b border-gray-100 hover:bg-gray-50 lg:hover:bg-transparent lg:border-0 lg:hover:text-primary-700 lg:p-0 dark:text-gray-400 lg:dark:hover:text-white dark:hover:bg-gray-700 dark:hover:text-white lg:dark:hover:bg-transparent dark:border-gray-700">
|
|
||||||
Features
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<a href="#"
|
|
||||||
class="block py-2 pr-4 pl-3 text-gray-700 border-b border-gray-100 hover:bg-gray-50 lg:hover:bg-transparent lg:border-0 lg:hover:text-primary-700 lg:p-0 dark:text-gray-400 lg:dark:hover:text-white dark:hover:bg-gray-700 dark:hover:text-white lg:dark:hover:bg-transparent dark:border-gray-700">
|
|
||||||
Team
|
|
||||||
</a>
|
|
||||||
</li>
|
|
||||||
<li>
|
<li>
|
||||||
<router-link
|
<router-link
|
||||||
to="/uploadpng"
|
to="/uploadpng"
|
||||||
|
|||||||
@@ -61,8 +61,9 @@
|
|||||||
<el-table-column prop="name" label="姓名" min-width="120" />
|
<el-table-column prop="name" label="姓名" min-width="120" />
|
||||||
<el-table-column prop="classId" label="班级ID" width="100" />
|
<el-table-column prop="classId" label="班级ID" width="100" />
|
||||||
<el-table-column prop="gradeId" label="年级ID" width="100" />
|
<el-table-column prop="gradeId" label="年级ID" width="100" />
|
||||||
<el-table-column label="操作" width="120" fixed="right">
|
<el-table-column label="操作" width="180" fixed="right">
|
||||||
<template #default="{ row }">
|
<template #default="{ row }">
|
||||||
|
<el-button type="primary" size="small" @click.stop="onViewStudent(row)">详情</el-button>
|
||||||
<el-button type="danger" size="small" @click.stop="onDeleteStudent(row)">删除</el-button>
|
<el-button type="danger" size="small" @click.stop="onDeleteStudent(row)">删除</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
@@ -167,6 +168,7 @@ import AddStudentDialog from '@/layouts/components/AddStudentDialog.vue'
|
|||||||
import LessonPlanDialog from '@/layouts/components/LessonPlanDialog.vue'
|
import LessonPlanDialog from '@/layouts/components/LessonPlanDialog.vue'
|
||||||
import { getUnitList, deleteUnit } from '@/api/unit'
|
import { getUnitList, deleteUnit } from '@/api/unit'
|
||||||
import AddUnitDialog from '@/layouts/components/AddUnitDialog.vue'
|
import AddUnitDialog from '@/layouts/components/AddUnitDialog.vue'
|
||||||
|
import { useRouter } from 'vue-router'
|
||||||
|
|
||||||
const classes = ref([])
|
const classes = ref([])
|
||||||
const pageNo = ref(1)
|
const pageNo = ref(1)
|
||||||
@@ -207,6 +209,7 @@ const unitTotalCount = ref(0)
|
|||||||
const unitLoading = ref(false)
|
const unitLoading = ref(false)
|
||||||
const unitTableRef = ref(null)
|
const unitTableRef = ref(null)
|
||||||
const showAddUnitDialog = ref(false)
|
const showAddUnitDialog = ref(false)
|
||||||
|
const router = useRouter()
|
||||||
|
|
||||||
async function fetchClasses() {
|
async function fetchClasses() {
|
||||||
loading.value = true
|
loading.value = true
|
||||||
@@ -289,6 +292,9 @@ function handleStudentSizeChange(s) {
|
|||||||
function onStudentSelectionChange(rows) {
|
function onStudentSelectionChange(rows) {
|
||||||
selectedStudentIds.value = rows.map(r => r.id)
|
selectedStudentIds.value = rows.map(r => r.id)
|
||||||
}
|
}
|
||||||
|
function onViewStudent(row) {
|
||||||
|
router.push(`/student/${row.id}`)
|
||||||
|
}
|
||||||
function onClassRowClick(row) {
|
function onClassRowClick(row) {
|
||||||
selectedClassId.value = row.id
|
selectedClassId.value = row.id
|
||||||
selectedClassTitle.value = row.title
|
selectedClassTitle.value = row.title
|
||||||
|
|||||||
55
enlish-vue/src/pages/student.vue
Normal file
55
enlish-vue/src/pages/student.vue
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
<template>
|
||||||
|
<div class="common-layout">
|
||||||
|
<el-container>
|
||||||
|
<el-header>
|
||||||
|
<Header></Header>
|
||||||
|
</el-header>
|
||||||
|
|
||||||
|
<el-main class="p-4">
|
||||||
|
<div class="bg-white dark:bg-gray-800 rounded-lg shadow p-6" v-loading="loading">
|
||||||
|
<div class="text-lg font-semibold mb-4">学生详情</div>
|
||||||
|
<template v-if="detail">
|
||||||
|
<el-descriptions :column="1" border>
|
||||||
|
<el-descriptions-item label="ID">{{ detail.id }}</el-descriptions-item>
|
||||||
|
<el-descriptions-item label="姓名">{{ detail.name }}</el-descriptions-item>
|
||||||
|
<el-descriptions-item label="班级">{{ detail.className }}</el-descriptions-item>
|
||||||
|
<el-descriptions-item label="年级">{{ detail.gradeName }}</el-descriptions-item>
|
||||||
|
</el-descriptions>
|
||||||
|
</template>
|
||||||
|
<template v-else>
|
||||||
|
<el-empty description="暂无数据" />
|
||||||
|
</template>
|
||||||
|
</div>
|
||||||
|
</el-main>
|
||||||
|
|
||||||
|
</el-container>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import Header from '@/layouts/components/Header.vue'
|
||||||
|
import { ref, onMounted } from 'vue'
|
||||||
|
import { useRoute } from 'vue-router'
|
||||||
|
import { getStudentDetail } from '@/api/student'
|
||||||
|
|
||||||
|
const loading = ref(false)
|
||||||
|
const detail = ref(null)
|
||||||
|
const route = useRoute()
|
||||||
|
|
||||||
|
async function fetchDetail() {
|
||||||
|
const id = route.params.id
|
||||||
|
if (!id) return
|
||||||
|
loading.value = true
|
||||||
|
try {
|
||||||
|
const res = await getStudentDetail(id)
|
||||||
|
const d = res.data
|
||||||
|
detail.value = d?.data || null
|
||||||
|
} finally {
|
||||||
|
loading.value = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
fetchDetail()
|
||||||
|
})
|
||||||
|
</script>
|
||||||
@@ -3,6 +3,7 @@ import Uploadpng from '@/pages/uploadpng.vue'
|
|||||||
import LearningPlan from '@/pages/LearningPlan.vue'
|
import LearningPlan from '@/pages/LearningPlan.vue'
|
||||||
import Class from '@/pages/class.vue'
|
import Class from '@/pages/class.vue'
|
||||||
import { createRouter, createWebHashHistory } from 'vue-router'
|
import { createRouter, createWebHashHistory } from 'vue-router'
|
||||||
|
import Student from '@/pages/student.vue'
|
||||||
|
|
||||||
// 统一在这里声明所有路由
|
// 统一在这里声明所有路由
|
||||||
const routes = [
|
const routes = [
|
||||||
@@ -26,6 +27,13 @@ const routes = [
|
|||||||
meta: { // meta 信息
|
meta: { // meta 信息
|
||||||
title: '学案' // 页面标题
|
title: '学案' // 页面标题
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: '/student/:id', // 路由地址
|
||||||
|
component: Student, // 对应组件
|
||||||
|
meta: { // meta 信息
|
||||||
|
title: '学生详情' // 页面标题
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user