前端vue+typeScritp+elementPlus基础页面实现:

news2025/4/22 4:41:27

效果:

前端代码:

index.vue:

<template>
  <el-container>
    <el-main>
      <el-card class="search-card" shadow="never">
        <transition :enter-active-class="proxy?.animate.searchAnimate.enter" :leave-active-class="proxy?.animate.searchAnimate.leave">
          <el-form :inline="true" class="demo-form-inline">
            <el-form-item label="专科名称:">
              <el-select v-model="queryParams.zhuanKeMingCheng" placeholder="请选择专科名称" filterable clearable>
                <el-option v-for="item in zhuanKeNameList" :key="item" :label="item" :value="item" />
              </el-select>
            </el-form-item>
            <el-form-item>
              <el-button type="primary" icon="Search" @click="onSearch">搜索</el-button>
            </el-form-item>
            <el-form-item>
              <el-button type="warning" icon="Plus" @click="showAddDialog">新增</el-button>
            </el-form-item>
          </el-form>
        </transition>
      </el-card>
      <el-card class="table-card" shadow="never">
        <el-table :data="tableData" border style="width: 100%">
          <el-table-column prop="nianFen" label="年份" width="100"></el-table-column>
          <el-table-column prop="yiYuanMingCheng" label="医院名称" width="180"></el-table-column>
          <el-table-column prop="zhuanKeMingCheng" label="专科名称" width="180"></el-table-column>
          <el-table-column prop="zhuanKeLeiBie" label="专科类别" width="180"></el-table-column>
          <el-table-column prop="neiWaiKe" label="内外科" width="180"></el-table-column>
          <el-table-column prop="zhuanKeDaiMa" label="专科代码" width="180"></el-table-column>
          <el-table-column label="状态" width="120">
            <template #default="scope">
              <div v-if="scope.row.zhuangTai === '1'">未开始</div>
              <div v-else-if="scope.row.zhuangTai === '2'">进行中</div>
              <div v-else-if="scope.row.zhuangTai === '3'">已完成</div>
            </template>
          </el-table-column>
          <el-table-column align="center" label="操作">
            <template #default="scope">
              <el-button size="small" plain type="primary" :disabled="scope.row.zhuangTai!=='1'" @click="handleProcess(scope.$index, scope.row)"
                >开始申报
              </el-button>
              <el-button size="small" plain type="danger" :disabled="scope.row.zhuangTai!=='1'" @click="handleDelete(scope.$index, scope.row)"
                >删除
              </el-button>
            </template>
          </el-table-column>
        </el-table>
        <pagination v-show="total>0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="fetchData" />
      </el-card>
    </el-main>

    <!-- 新增对话框 -->
    <el-dialog v-model="addDialogVisible" title="新增申报" width="30%">
      <el-form :model="addForm" ref="addFormRef" :rules="rules" label-width="100px">
        <el-form-item required label="年份" prop="nianFen">
          <el-date-picker  v-model="addForm.nianFen" type="year" placeholder="选择年" format="YYYY" value-format="YYYY" ></el-date-picker>
        </el-form-item>
        <el-form-item required label="专科名称" prop="zhuanKeName">
          <el-select v-model="addForm.zhuanKeName" placeholder="请选择专科名称">
            <el-option v-for="item in zhuanKeNameList" :key="item" :label="item" :value="item" />
          </el-select>
        </el-form-item>
        <el-form-item required label="专科类别" prop="zhuanKeLeiBie">
          <el-select v-model="addForm.zhuanKeLeiBie" style="width: 150px" clearable>
            <el-option v-for="item in zhuan_ke_type" :value="item.value" :label="item.label" />
          </el-select>
        </el-form-item>
      </el-form>
      <template #footer>
        <span class="dialog-footer">
          <el-button @click="addDialogVisible = false">取消</el-button>
          <el-button type="primary" @click="submitAddForm">提交</el-button>
        </span>
      </template>
    </el-dialog>
  </el-container>
</template>

<script setup lang="ts">
import {ref, onMounted, toRefs, getCurrentInstance} from 'vue';
import {
  addZhuanKeShenBao,
  getZhuanKeNameList,
  getZhuanKeShenBaoList,
  deleteZhuanKeShenBao, startShenBao
} from '@/api/keyspecialty/zhuanKeShenBao';
import {zhuankeShenBaoVo} from "@/api/keyspecialty/zhuanKeShenBao/types";
import {ElMessage} from 'element-plus';
const queryParams = ref({
  pageNum: 1,
  pageSize: 10,
  zhuanKeName: "",
  hospName: "",
})
const {proxy} = getCurrentInstance() as ComponentInternalInstance;
const {zhuan_ke_type} = toRefs<any>(proxy?.useDict("zhuan_ke_type"));

//专科名称列表
const zhuanKeNameList = ref([]);
// 表格数据
const tableData = ref<zhuankeShenBaoVo[]>([]);
const total = ref(0);
// 获取数据的函数
const fetchData = async () => {
  try {
    const response = await getZhuanKeShenBaoList(queryParams.value);
    tableData.value = response.rows;
    total.value = response.total;
  } catch (error) {
    console.error('Error fetching data:', error);
  }
};

// 页面加载时获取数据
onMounted(() => {
  fetchData();
  getZhuanKeNameListData();
});

// 查询按钮点击事件
const onSearch = () => {
  fetchData();
  console.log('查询');
};

// 显示新增对话框
const addDialogVisible = ref(false);
const showAddDialog = () => {
  //重置表单数据
  addForm.value = {
    zhuanKeName: '',
    zhuanKeLeiBie: '',
    nianFen:'',
  };
  addDialogVisible.value = true;
};
// 新增表单数据
const addForm = ref({
  zhuanKeName: '',
  zhuanKeLeiBie: '',
  nianFen:'',
});
// 表单ref
const addFormRef = ref();
// 提交新增表单
const submitAddForm = () => {
  addFormRef.value?.validate((valid: boolean) => {
    if (valid) {
      console.log('提交新增表单', addForm.value);
      addZhuanKeShenBao(addForm.value.zhuanKeName, addForm.value.zhuanKeLeiBie, addForm.value.nianFen).then((res) => {
        if (res.code === 200) {
          ElMessage.success('申报成功');
          fetchData();
          addDialogVisible.value = false;
        } else {
          ElMessage.error('申报失败');
          ElMessage.error(res.msg);
        }
      });
    } else {
      ElMessage.error('请填写完整信息');
    }
  });
};
const rules = {
  nianFen: [
    { required: true, message: '请选择年份', trigger: 'change' }
  ],
  zhuanKeName: [
    { required: true, message: '请选择专科名称', trigger: 'change' }
  ],
  zhuanKeLeiBie: [
    { required: true, message: '请选择专科类别', trigger: 'change' }
  ]
};
//获取专科名称列表
const getZhuanKeNameListData = async () => {
  try {
    const response = await getZhuanKeNameList();
    zhuanKeNameList.value = response.data;
    console.log('专科名称列表', zhuanKeNameList.value);
  } catch (error) {
    console.error('Error fetching data:', error);
  }
}
// 申报流程按钮点击事件
const handleProcess = (index: number, row: any) => {
  startShenBao(row.id).then((res) => {
    if (res.code == 200) {
      ElMessage.success('申报流程开始');
      fetchData();
    } else {
      ElMessage.error('申报流程开始失败');
      fetchData();
    }
  })
};

// 删除按钮点击事件
const handleDelete = (index: number, row: any) => {
  ElMessageBox.confirm('确认删除?', '提示', {
    confirmButtonText: '确定',
    cancelButtonText: '取消',
    type: 'warning',
  }).then(() => {
    deleteZhuanKeShenBao(row.id).then((res) => {
      if (res.code === 200) {
        ElMessage.success('删除成功');
        fetchData();
      } else {
        ElMessage.error('删除失败');
        fetchData();
        return;
      }
    });
  })
};
</script>
<style scoped lang="scss">
.el-main {
  padding: 20px;

  .search-card {
    margin-bottom: 20px;
  }

  .table-card {
    padding: 10px;
  }
}
</style>

index.ts:

import request from '@/utils/request';
import { AxiosPromise } from 'axios';
import {zhuankeShenBaoQuery, zhuankeShenBaoVo} from "@/api/keyspecialty/zhuanKeShenBao/types";

/**
 * 新增专科申报
 * @param data
 */
export const addZhuanKeShenBao = (zhuanKeName: string, zhuanKeLeiBie: string) => {
  return request({
    url: 'zhuanKeShenBao/addZhuanKeShenBao/' + zhuanKeName + '/' + zhuanKeLeiBie,
    method: 'post',
  });
};
//获取专科名称列表
export const getZhuanKeNameList = () => {
  return request({
    url: 'zhuanKeShenBao/getZhuankeNameList',
    method: 'get',
  });
};
//分页查询专科申报列表
export const getZhuanKeShenBaoList = (params: zhuankeShenBaoQuery) : AxiosPromise<zhuankeShenBaoVo[]>=> {
  return request({
    url: '/zhuanKeShenBao/getZhuanKeShenBaoList',
    method: 'get',
    params,
  });
}

type.ts

export interface zhuankeShenBaoQuery extends PageQuery{
  hospName:string,
  zhuanKeName:string
}
export interface zhuankeShenBaoVo{
  yiYuanId:number,
  yiYuanMingCheng:string,
  zhuanKeDaiMa:string,
  zhuanKeMingCheng:string,
  zhuanKeLeiBie:string,
  zhuangTai:string,
  isTuiJian:string,
  neiWaiKe:string
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2339845.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

leetcode第20题(有效的括号)

思路解析&#xff08;使用栈&#xff09;&#xff1a; 使用一个栈来保存左括号。 每当遇到一个右括号时&#xff0c;检查栈顶元素是否是匹配的左括号。 如果匹配&#xff0c;则弹出栈顶元素&#xff1b; 如果不匹配或者栈为空&#xff0c;则说明无效&#xff1b; 最后如果栈…

超简单的git学习教程

本博客仅用于记录学习和使用 前提声明全部内容全部来自下面廖雪峰网站&#xff0c;如果侵权联系我删除 0.前言 相信有不少人被推荐那个游戏学习git&#xff0c;一个不止我一个完全没学习过的进去后一脸懵&#xff0c;半天都通不过一关然后就放弃了&#xff0c;我个人觉得那个…

【DVWA File Upload 漏洞实战指南】(Low / Medium / High 全级别解析)

前言 文件上传功能是 Web 应用中非常常见的一种功能&#xff0c;用于上传头像、文档、图片等文件。但如果验证不当&#xff0c;攻击者可能上传恶意脚本&#xff0c;进而控制服务器。在 DVWA 中&#xff0c;File Upload 模块专门设计用于演练此类漏洞的不同防御等级。 一、Low …

iPhone 13P 换超容电池,一年实记的“电池循环次数-容量“柱状图

继上一篇 iPhone 13P 更换"移植电芯"和"超容电池"&#x1f50b;体验&#xff0c;详细记录了如何更换这两种电池&#xff0c;以及各自的优略势对比。 一晃一年过去&#xff0c;时间真快&#xff0c;这次分享下记录了使用超容电池的 “循环次数 - 容量(mAh)…

【集群IP管理分配技术_DHCP】一、DHCP技术概念与快速上手

在网络技术飞速发展的今天&#xff0c;动态主机配置协议&#xff08;DHCP&#xff09;作为网络中自动分配 IP 地址及相关配置参数的重要工具&#xff0c;极大地简化了网络管理流程。然而&#xff0c;随着网络规模的不断扩大和应用场景的日益复杂&#xff0c;传统 DHCP 在灵活性…

Tailwindcss 入门 v4.1

以 react 为例&#xff0c;步骤如下&#xff1a; npm create vitelatest my-app -- --template react 选择 React 和 JavaScript 根据上述命令的输出提示&#xff0c;运行以下命令 cd my-app npm install npm run dev 一个 React App 初始化完成。 安装 Tailwindcss theme …

【Linux】NAT、代理服务、内网穿透

NAT、代理服务、内网穿透 一. NAT1. NAT 技术2. NAT IP 转换过程3. NAPT 技术4. NAT 技术的缺陷 二. 代理服务器1. 正向代理2. 反向代理3. NAT 和代理服务器 内网穿透内网打洞 一. NAT NAT&#xff08;Network Address Translation&#xff0c;网络地址转换&#xff09;技术&a…

PCA——主成分分析数学原理及代码

主成分分析 PCA的目的是&#xff1a;对数据进行一个线性变换&#xff0c;在最大程度保留原始信息的前提下去除数据中彼此相关的信息。反映在变量上就是说&#xff0c;对所有的变量进行一个线性变换&#xff0c;使得变换后得到的变量彼此之间不相关&#xff0c;并且是所有可能的…

【技术派后端篇】Redis实现统计计数

在互联网项目中&#xff0c;计数器有着广泛的应用场景。以技术派项目为例&#xff0c;诸如文章点赞数、收藏数、评论数以及用户粉丝数等都离不开计数器的支持。在技术派源码中&#xff0c;提供了基于数据库操作记录实时更新和基于 Redis 的 incr 特性实现计数器这两种方案&…

JavaWeb 课堂笔记 —— 16 MyBatis 动态SQL

本系列为笔者学习JavaWeb的课堂笔记&#xff0c;视频资源为B站黑马程序员出品的《黑马程序员JavaWeb开发教程&#xff0c;实现javaweb企业开发全流程&#xff08;涵盖SpringMyBatisSpringMVCSpringBoot等&#xff09;》&#xff0c;章节分布参考视频教程&#xff0c;为同样学习…

Deepseek输出的内容如何直接转化为word文件?

我们有时候会直接利用deepseek翻译别人的文章或者想将deepseek输出的内容直接复制到word文档里。但是文本格式和word是不对应的。这时候需要输入如下命令&#xff1a; 以上翻译内容的格式和排版要求如下&#xff1a; 1、一级标题 字体为黑体&#xff08;三号&#xff09;&…

AI融合SEO关键词实战指南

内容概要 随着人工智能技术的迭代升级&#xff0c;SEO关键词策略正经历从人工经验驱动向数据智能驱动的范式转变。本指南聚焦AI技术在搜索引擎优化中的系统性应用&#xff0c;通过构建多层技术框架实现关键词全生命周期管理。核心方法论涵盖语义分析引擎的构建原理、基于NLP的…

快速入手-基于python和opencv的人脸检测

1、安装库 pip install opencv-python 如果下载比较卡的话&#xff0c;指向国内下载地址&#xff1a; pip3 install opencv-python -i https://pypi.tuna.tsinghua.edu.cn/simple 2、下载源码 https://opencv.org/ windows11对应的版本下载&#xff1a; https://pan.baidu…

汽车免拆诊断案例 | 2011款雪铁龙世嘉车刮水器偶尔自动工作

故障现象 一辆2011款雪铁龙世嘉车&#xff0c;搭载1.6 L 发动机&#xff0c;累计行驶里程约为19.8万km。车主反映&#xff0c;该车刮水器偶尔会自动工作&#xff0c;且前照灯偶尔会自动点亮。 故障诊断 接车后试车发现&#xff0c;除了上述故障现象以外&#xff0c;当用遥控器…

8.QT-按钮类控件|Push Button|Radio Button|Check Box|Tool Button(C++)

Push Button 使⽤ QPushButton 表⽰⼀个按钮.这也是当前我们最熟悉的⼀个控件了. QPushButton 继承⾃ QAbstractButton .这个类是⼀个抽象类.是其他按钮的⽗类 在Qt Designer中也能够看到这⾥的继承关系 属性说明text按钮中的⽂本icon按钮中的图标iconSize按钮中图标的尺⼨sh…

STM32嵌入式

一、创建工程项目 1、进入软件首页 2、新建项目,【file】->【new project】 3、选择需要的芯片 4、系统内核部分设置 ① 选择晶振&#xff08;使用外部的高速晶振&#xff09; ② 选择debug形式&#xff08;SW类型&#xff09; 5、时钟设置 6、选择自己需要的引脚设置&a…

Transformer系列(一):NLP中放弃使用循环神经网络架构

NLP中放弃使用循环神经网络架构 一、符号表示与概念基础二、循环神经网络1. 依赖序列索引存在的并行计算问题2. 线性交互距离 三、总结 该系列笔记阐述了自然语言处理&#xff08;NLP&#xff09;中不再采用循环架构&#xff08;recurrent architectures&#xff09;的原因&…

9.QT-显示类控件|Label|显示不同格式的文本|显示图片|文本对齐|自动换行|缩进|边距|设置伙伴(C++)

Label QLabel 可以⽤来显⽰⽂本和图⽚ 属性说明textQLabel中的⽂本textFormat⽂本的格式.• Qt::PlainText 纯⽂本• Qt::RichText 富⽂本(⽀持html标签)• Qt::MarkdownText markdown格式• Qt::AutoText 根据⽂本内容⾃动决定⽂本格式pixmapQLabel 内部包含的图⽚.scaledCo…

【c语言】深入理解指针1

深入理解指针1 一、数组名的理解二、使用指针访问数组三、一维数组传参本质四、二级指针 一、数组名的理解 数组名就是数组首元素的地址&#xff0c;类型是指针类型&#xff0c;但是存在两个例外&#xff1a; sizeof(arr) : 整个数组在内存中的大小 &arr : 整个数组的地址…

4.QT-信号和槽|存在意义|信号和槽的连接方式|信号和槽断开|lambda表达式|信号和槽优缺点(C++)

信号和槽存在意义 所谓的信号槽&#xff0c;终究要解决的问题&#xff0c;就是响应用户的操作 信号槽&#xff0c;其实在GUI开发的各种框架中&#xff0c;是一个比较有特色的存在 其他的GUI开发框架&#xff0c;搞的方式都要更简洁一些&#xff5e;~ 网页开发 (js dom api) 网…