vite+vue3+ts开发流程

news2025/1/22 20:53:28

目录

vue页面开发

数据类型开发

组件开发

API开发

页面中使用组件、API、数据类型


  1. vue页面开发

    1. <template>
          <!--    卡片区域-->
          <el-card style="padding:0px;">
              <!--      搜索与添加区域-->
              <div style="margin-bottom: 15px;">
                  <el-row :gutter="20">
                      <el-col :lg="5" :xs="15" :md="5" :sm="5">
                          <el-input placeholder="请输入内容" :suffix-icon="Search" v-model="queryInfo.obj.userName" :clearable="true"
                              v-permission="{ action: 'system:user:query' }" @clear="clear()">
                              <component class="icon" @click="search" :is="Search" />
                          </el-input>
                      </el-col>
                      <el-col :lg="5" :xs="5" :md="5" :sm="5">
                          <el-button type="primary" @click="addBtn" v-permission="{ action: 'system:user:add' }">添加
                          </el-button>
                      </el-col>
                  </el-row>
              </div>
              <!--      用户列表区-->
              <el-table :data="list" stripe>
                  <el-table-column type="index" label="#"></el-table-column>
                  <el-table-column label="用户名" prop="userName"></el-table-column>
                  <el-table-column label="昵称" prop="nickName"></el-table-column>
                  <el-table-column label="部门" prop="deptName"></el-table-column>
                  <el-table-column label="手机" prop="phonenumber"></el-table-column>
                  <el-table-column label="邮箱" prop="email"></el-table-column>
                  <el-table-column label="状态" prop="status">
                      <template #default="scope">
                          <el-switch v-model="scope.row.status" class="ml-2" inline-prompt active-value="0" inactive-value="1"
                              style="--el-switch-on-color: #13ce66; --el-switch-off-color: #ff4949" active-text="正常"
                              inactive-text="禁用" />
                      </template>
                  </el-table-column>
                  <el-table-column label="操作" width="180px">
                      <template #default="scope">
                          <el-button type="primary" :icon="Edit" size="small" @click="editBtn(scope.row)"
                              v-permission="{ action: 'system:user:add' }"></el-button>
                          <el-button type="danger" :icon="Delete" size="small" @click="deleteBtn(scope.row)"
                              v-permission="{ action: 'system:user:add' }"></el-button>
                          <el-tooltip effect="dark" content="分配角色" placement="top" :enterable="false">
                              <el-button type="warning" :icon="Setting" size="small" @click="grantBtn(scope.row)"
                                  v-permission="{ action: 'system:user:add' }"></el-button>
                          </el-tooltip>
                      </template>
                  </el-table-column>
              </el-table>
              <div style="padding-top: 30px;">
                  <el-pagination background layout="total, sizes, prev, pager, next, jumpe" :total="1000" />
              </div>
          </el-card>
          <addUser ref="addUserRef"></addUser>
      </template>
        
      <script lang="ts" setup true>
      import { Delete, Edit, Search, Setting } from '@element-plus/icons-vue';
      import addUser from './addUser.vue';
      import tableList from './tableList';
      
      const { queryInfo, list, addUserRef, search, clear, addBtn, editBtn, deleteBtn, grantBtn } = tableList()
      
      </script>
        
      <style scoped></style>
        
  2. 数据类型开发

    1. export type UserModel = {
          code: number,
          msg: string,
          page: {
              list: {
                  userName: string,
                  nickName: string,
                  email: string,
                  sex: string,
                  status: string,
                  phonenumber: string,
                  deptName: string
              },
              totalCount: number
          }
      }
      export type QueryInfoModel = {
          pageNum: number,
          pageSize: number,
          total: number
          obj: {
              userName: string,
              email: string,
              phonenumber: string
          }
      }
      
      export type AddUserMode = {
          userName: string,
          nickName: string,
          email: string,
          password: string,
          sex: string,
          status: string,
          phonenumber: string,
          deptId: string,
          deptName:string,
          remark: string
      }
      
      
  3. 组件开发

    1. import { onMounted, reactive, ref } from "vue";
      import { QueryInfoModel } from "@/api/model/user/userModel";
      import { getListAPI } from "@/api/model/user";
      //表格相关的业务处理
      export default function tableList() {
          const addUserRef = ref<{ show: () => void }>()
          const queryInfo = reactive<QueryInfoModel>({
              pageNum: 1,
              pageSize: 10,
              total: 0,
              obj: {
                  userName: '',
                  email: '',
                  phonenumber: ''
              }
          })
          const list = ref([] as any)
          //列表
          const getList = async () => {
              let res = await getListAPI(queryInfo)
              console.info(res)
              if (res && res.code == 200) {
                  list.value = res.page.list
                  queryInfo.total = res.page.totalCount
              }
          }
          //搜索
          const search = () => {
      
          }
      
          //清除
          const clear = () => {
      
          }
      
          //添加
          const addBtn = () => {
              addUserRef.value?.show()
          }
          //修改
          const editBtn = (row: any) => {
      
          }
          //删除
          const deleteBtn = (row: any) => {
      
          }
          //授权
          const grantBtn = (row: any) => {
      
          }
      
      
          onMounted(() => {
              getList()
          })
      
          return {
              queryInfo,
              list,
              addUserRef,
              getList,
              search,
              clear,
              addBtn,
              editBtn,
              deleteBtn,
              grantBtn
          }
      }
  4. API开发

    1. import http from "../../http";
      import { UserModel, QueryInfoModel, AddUserMode } from "./userModel";
      //list
      export const getListAPI = (params: QueryInfoModel) => {
          return http.post<UserModel>('admin/sysUser/list', params)
      }
      //add
      export const addUserAPI = (params: AddUserMode) => {
          return http.post<UserModel>('admin/sysUser/addUser', params)
      }
  5. 页面中使用组件、API、数据类型

    1. <script lang="ts" setup true>
      import { Delete, Edit, Search, Setting } from '@element-plus/icons-vue';
      import addUser from './addUser.vue';
      import tableList from './tableList';
      
      const { queryInfo, list, addUserRef, search, clear, addBtn, editBtn, deleteBtn, grantBtn } = tableList()
      
      </script>
        
      <style scoped></style>
        

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

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

相关文章

SAP ABAP selection screen 动态获取字段名不需要回车触发

SAP ABAP selection screen &#xff0c;get field vaule without click Enter key. 有个需求&#xff0c;界面上几个字段的搜索帮助需要根据已输入值联动&#xff0c;比如AOP version 根据已输入的BU 过滤。 但尴尬的是在事件AT SELECTION-SCREEN ON VALUE-REQUEST FOR 中&a…

.Net中的标识框架Identity

中间件&#xff1a; 1、Authentication对访问者的用户身份进行验证&#xff0c;“用户是否登录成功”。 2、Authorization验证访问者的用户身份是否有对资源访问的访问权限&#xff0c;“用户是否有权限访问这个地址”。 简单描述 1、标识&#xff08;Identity&#xff09;框架…

TCP协议二:TCP状态转换(重要)

TCP状态转换分析https://www.bilibili.com/video/BV1iJ411S7UA?p44&spm_id_frompageDriver&vd_sourced239c7cf48aa4f74eccfa736c3122e65 TCP状态转换图 粗实线&#xff1a;主动端 虚线&#xff1a; 被动端 细实线&#xff1a;内核操作 状态分析 CLOSED&#xff1…

RabbitMQ:消息中间件

文章目录 概念管理界面简介4中常见交换器类型1.Direct交换器:2.Fanout交换器3.Topic交换器4.headers交换器 对象类型消息传递同步等待使用代码创建队列待续...... 概念 在微服务架构中项目之间项目A调用项目B 项目B调用项目C项目C调用项目D。。 用户必须等待项目之间内容依次的…

后端太难了,不 All in 了

作者&#xff1a;阿秀 校招八股文学习网站&#xff1a;https://interviewguide.cn 这是阿秀的第「256」篇原创 小伙伴们大家好&#xff0c;我是阿秀。 欢迎今年参加秋招的小伙伴加入阿秀的学习圈&#xff0c;目前已经超过 2200 小伙伴加入&#xff01;去年认真准备和走下来的基…

Segment Anything Model代码讲解(二)之image_encoder

image_encoder代码解析 在transformer的结构中&#xff0c;编码是非常重要的部分。接下来看image_encoder的代码部分目录 class ImageEncoderViT def initdef forward class Block def initdef forward class Attention def initdef forward def window_partitiondef window_…

【C++】引用(下)【深度全面解析】

&#x1f339;作者:云小逸 &#x1f4dd;个人主页:云小逸的主页 &#x1f4dd;Github:云小逸的Github &#x1f91f;motto:要敢于一个人默默的面对自己&#xff0c;强大自己才是核心。不要等到什么都没有了&#xff0c;才下定决心去做。种一颗树&#xff0c;最好的时间是十年前…

自定义类型——枚举与联合体

枚举 枚举顾名思义就是一一列举 把可能的取值一一列举 枚举类型的定义 enum Day//星期 {Mon,Tues,Wed,Thur,Fri,Sat,Sun };enum Sex//性别 {MALE,FEMALE,SECRET }&#xff1b;以上定义的 enum Day &#xff0c; enum Sex 都是枚举类型 { }中的内容是枚举类型的可能取值&…

English Learning - L2 第 14 次小组纠音 复习元音 [ɔɪ ] [aʊ] [əʊ] [ɪə] 弱读 2023.4.12 周三

English Learning - L2 第 14 次小组纠音 复习元音 [ɔɪ ] [aʊ] [əʊ] [ɪə] 弱读 2023.4.12 周三 共性问题coin voice /kɔɪn/ /vɔɪs/ 中 ɔɪvowel pounds /ˈvaʊəl/ /paʊndz/ 中的 aʊshow /ʃəʊ/beer nearly /bɪə/ /ˈnɪəlɪ/ 中的 ɪəbest bed ten /best…

U-Boot 烧写与启动

1.uboot 编译好以后就可以烧写到板子上使用了&#xff0c;这里我们跟前面裸机例程一样&#xff0c;将 uboot 烧写到 SD 卡中&#xff0c;然后通过 SD 卡来启动来运行 uboot。使用 imxdownload 软件烧写&#xff0c;命令如 下&#xff1a; chmod 777 imxdownload //给予 imxdo…

超参数的设置;使用适当的尺度来选择超参数;批量归一化;测试时的批量标准化:

超参数的设置&#xff1a; 超参数之间也有重要性差异。通常来说&#xff0c;学习因子α是最重要的超参数&#xff0c;也是需要重点调试的超参数。动量梯度下降因子β、各隐藏层神经元个数#hidden units和mini-batch size的重要性仅次于α。然后就是神经网络层数#layers和学习因…

【Python38安装PyAudio过程出现错误如:Failed building wheel for PyAudio等一系列问题】

安装PyAudio过程出现错误&#xff1a;Failed building wheel for PyAudio 目前成功解决解决过程&#xff08;1&#xff09; 解决方法1 查看pip支持安装whl文件的命名方式:没解决&#xff08;2&#xff09;解决方法2 直接用终端解决 目前成功解决 环境&#xff1a;Windows11、p…

数据库实验 | 第2关:建立和调用存储过程(带输出参数)

任务描述 本关任务&#xff1a; 销售数据库有工作人员、销售单数据表 工作人员gzry数据表有雇员号gyh、姓名gyxm、出生日期csrq、学历xl、工资gz、部门bm、电话dh字段 销售单xsd数据表有销售单号xsdh、会员号hyh、雇员号gyh、销售日期xsrq、应付款yfk、实际付款sjfk字段 任…

JKind入门(二)引擎简介 BMC

如上文所说&#xff0c;JKind 使用了多个并行引擎&#xff0c;协调它们来证明需要检验属性。本文主要介绍 bounded model checking (BMC) 有界模型检验。其中会涉及到有关JKind的 K-induction &#xff08;k归纳引擎&#xff09;和 SMT求解机。 本来这些文章就是单纯就是自己的…

C语言进阶之内存操作函数

我们上一期学习的是字符串函数&#xff0c;只能操作字符串&#xff0c;如果我们想拷贝等等操作给一个整型数据或者浮点型数据&#xff0c;又该怎么办呢&#xff0c;就用到我们今天要学的内存操作函数 memcpy 内存拷贝 memmove 内存移动 memset 内存设计 memcpy操作 先来…

【Webpack】前端工程化与webpack

文章目录前端工程化1、小白眼中的前端开发 vs 实际的前端开发2、什么是前端工程化3、前端工程化的解决方案Webpack的基本使用1、什么是 webpack2、创建列表隔行变色项目3、在项目中安装webpack4、在项目中配置webpackWebpack中的插件1、webpack插件的作用2、webpack-dev -serve…

IntersectionObserver与无限滚动加载

学习链接 IntersectionObserver MDN Api IntersectionObserver API详解 Intersection observer 的概念和用法 过去&#xff0c;要检测一个元素是否可见或者两个元素是否相交并不容易&#xff0c;比如实现图片懒加载、内容无限滚动等功能时&#xff0c;都需要通过​getBound…

Java语法理论和面经杂疑篇《十一. JDK8新特性》

目录 1. Java版本迭代概述 1.1 发布特点&#xff08;小步快跑&#xff0c;快速迭代&#xff09; 1.2 名词解释 1.3 各版本支持时间路线图 1.4 各版本介绍 1.5 JDK各版本下载链接 1.6 如何学习新特性 2. Java8新特性&#xff1a;Lambda表达式 2.1 关于Java8新特性简介 …

C# | 上位机开发新手指南(十)加密算法——ECC

上位机开发新手指南&#xff08;十&#xff09;加密算法——ECC 文章目录 上位机开发新手指南&#xff08;十&#xff09;加密算法——ECC前言ECC的特性非对称性可逆性签名安全性高计算量和存储空间小 对比ECC与RSAC#中如何使用ECC加密与解密数据导入与导出秘钥签名与验证 结束…

PyQt Custom Widget

pyuic/pyside6-uic pip install PyQt6 pyqt6-tools或者 pip install PySide6假设你的自定义控件时from vtk.test2.testhead import testfaQ 首先拉一个QWidget 右键Promote to… 在header file里写上 vtk.test2.testhead&#xff08;写vtk/test2/testhead.h或者vtk/test2/te…