Vue开发实例(十一)用户列表的实现与操作

用户列表的实现与操作

  • 一、创建用户页面和路由
  • 二、表格优化
    • 1、表头自定义
    • 2、表格滚动
    • 3、加入数据索引
    • 4、利用插槽自定义显示
  • 三、功能
    • 1、查询功能
    • 3、增加
    • 4、删除
    • 5、修改

一、创建用户页面和路由

  1. 创建用户页面

src/components/Main 下创建文件夹user,创建文件UserList.vue,文件内容如下:

页面中数据的请求代码:

  • 定义方法getUserData,使用axios 去请求数据,并将请求的数据设置给userData。
  • 在created钩子函数中调用getUserData方法。
<template>
  <el-table
    :data="userData"
    style="width: 100%"
    border
    :default-sort="{ prop: 'date', order: 'descending' }"
  >
    <el-table-column prop="date" label="日期" sortable width="180">
    </el-table-column>
    <el-table-column prop="name" label="姓名" sortable width="180">
    </el-table-column>
    <el-table-column prop="address" label="地址"> </el-table-column>
  </el-table>
</template>

<script>
export default {
  name: "UserList",
  data() {
    return {
      userData: [],
    };
  },
  methods: {
    getUserData() {
      this.$axios.post("/post/userList").then((res) => {
        this.userData = res.data.userData;
      });
    },
  },
  created() {
    this.getUserData();
  },
};
</script>

<style scoped>
.el-table {
  width: 100%;
  height: auto;
}
</style>
  1. 在之前使用的mockjs中,将菜单数据进行修改,然后加入用户管理的数据
Mock.mock('/post/menuList', 'get', function () {
  const menu_data = [
    {
      name: '用户管理',
      icon: 'el-icon-user',
      path: '/index/userList',
      component: 'user/UserList'
    },
    {
      name: '一级菜单1',
      icon: 'el-icon-location',
      path: '/index/menu1',
      component: 'Main1'
    },
    {
      name: '一级菜单2',
      icon: 'el-icon-document',
      path: '/index/menu2',
      component: 'Main2'
    }
  ]
  return {
    menu_data
  }
});

Mock.mock('/post/userList', 'post', function () {
  const userData = [
    {
      date: "2022-05-02",
      name: "牛3号",
      address: "北京市XXXXXX路1号",
    },
    {
      date: "2022-05-04",
      name: "牛4号",
      address: "北京市XXXXXX路2号",
    },
    {
      date: "2022-05-01",
      name: "牛5号",
      address: "北京市XXXXXX路3号",
    },
  ]
  return {
    userData
  }
});

页面效果
在这里插入图片描述

二、表格优化

1、表头自定义

  1. el-table 增加属性 header-row-class-name 值为 table_header_class
  2. 设置样式,注意使用:/deep/ .table-header-class th

参考代码:

<template>
  <el-table
    :data="userData"
    style="width: 100%"
    border
    :default-sort="{ prop: 'date', order: 'descending' }"
    header-row-class-name="table-header-class"
  >
    <el-table-column prop="date" label="日期" sortable width="180">
    </el-table-column>
    <el-table-column prop="name" label="姓名" sortable width="180">
    </el-table-column>
    <el-table-column prop="address" label="地址"> </el-table-column>
  </el-table>
</template>

<script>
export default {
  name: "UserList",
  data() {
    return {
      userData: [],
    };
  },
  methods: {
    getUserData() {
      this.$axios.post("/post/userList").then((res) => {
        this.userData = res.data.userData;
      });
    },
  },
  created() {
    this.getUserData();
  },
};
</script>

<style scoped>

.el-table {
  width: 100%;
  height: auto;
}

/deep/ .table-header-class th{
  background-color: #91a8b1 !important;
  color: white;
}
</style>

页面效果
在这里插入图片描述

2、表格滚动

如果数据过多则需要加入表格滚动,否则是外部滚动很难看,这种情况处理起来比较简单,在el-table加入max-height属性即可,比如我设置值为500px
在这里插入图片描述

效果展示
在这里插入图片描述

3、加入数据索引

加入数据索引
给表格加上一列即可,设置 type=“index”

<el-table-column type="index" width="50"></el-table-column>

在这里插入图片描述

4、利用插槽自定义显示

让数据看起来更显眼、分类更明确,比如 userData 加了tag,表示地址是工作地址,还是家

<el-table-column prop="tag" label="标签"></el-table-column>

页面效果
在这里插入图片描述
只加个标签的话,很平淡,我们用插槽试一下

<el-table-column prop="tag" label="标签">
      <template slot-scope="scope">
        <el-tag
          :type="scope.row.tag === '家' ? 'primary' : 'success'"
          disable-transitions
          >{{ scope.row.tag }}</el-tag
        >
      </template>
    </el-table-column>

页面效果
在这里插入图片描述

三、功能

1、查询功能

  1. 页面添加搜索框和搜索按钮,在table的前面加入代码
  2. 在data里面定义search_name,对应el-input的v-model

userList代码

<template>
  <div id="button_div">
    <el-input
      id="search-input"
      size="small"
      label-width="100px"
      prefix-icon="el-icon-search"
      placeholder="请输入名字..."
      v-model="search_name"
      style="height: auto; width: 20%"
    >
    </el-input>
    &nbsp;
    <el-button
      type="primary"
      size="small"
      class="search-button"
      @click="search"
      style="height: auto"
      >搜索</el-button
    >

    <el-table
      :data="userData"
      style="width: 100%"
      border
      :default-sort="{ prop: 'date', order: 'descending' }"
      header-row-class-name="table-header-class"
      class="custom-table-height"
      max-height="500px"
    >
      <el-table-column type="index" width="50"> </el-table-column>
      <el-table-column prop="date" label="日期" sortable width="180">
      </el-table-column>
      <el-table-column prop="name" label="姓名" sortable width="180">
      </el-table-column>
      <el-table-column prop="address" label="地址"> </el-table-column>
      <el-table-column prop="tag" label="标签">
        <template slot-scope="scope">
          <el-tag
            :type="scope.row.tag === '家' ? 'primary' : 'success'"
            disable-transitions
            >{{ scope.row.tag }}</el-tag
          >
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>

<script>
export default {
  name: "UserList",
  data() {
    return {
      userData: [],
      search_name: "",
    };
  },
  methods: {
    getUserData() {
      this.$axios.post("/post/userList").then((res) => {
        this.userData = res.data.userData;
      });
    },
    search() {
      console.log('this.search_name',this.search_name)
      this.$axios.post("/post/searchUser", { name: this.search_name })
        .then((res) => {
          console.log('name===',name)
          this.userData = res.data.userData;
        });
    },
  },
  created() {
    this.getUserData();
  },
};
</script>

<style scoped>
/* .el-table {
  width: 100%;
  height: 300px !important;
} */

/deep/ .table-header-class th {
  background-color: #91a8b1 !important;
  color: white;
}
.custom-table-height {
  height: auto !important; /* 或指定一个固定高度,例如 400px */
}
</style>

mockjs代码

const userData = [
  {
    date: "2022-05-02",
    name: "牛3号",
    address: "北京市XXXXXX路1号",
    tag: '家'
  },
  {
    date: "2022-05-04",
    name: "牛4号",
    address: "北京市XXXXXX路2号",
    tag: '家'
  },
  {
    date: "2022-05-01",
    name: "牛5号",
    address: "北京市XXXXXX路3号",
    tag: '家'
  },
]
Mock.mock('/post/searchUser', 'post', function (param) {
  console.log('param',param.body);
  let body = JSON.parse(param.body);
  let name = body.name;
  let newData = []
  if (name) {
    newData = userData.filter((item) => {
      console.log('*******',item.name.indexOf(name))
      return item.name.indexOf(name) > -1;
    })
    console.log('eeee',newData)
  } else {
    newData = userData;
    console.log('eeee2',newData)
  }
  return {
    userData: newData
  }
});

测试如下
在这里插入图片描述

3、增加

4、删除

5、修改


休息一会,继续补充~

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

java spring 02. AbstractApplicationContext

spring创建对象的顺序&#xff0c;先创建beanfactory&#xff0c;再会把xml文件读取到spring。 public ClassPathXmlApplicationContext(String[] configLocations, boolean refresh, Nullable ApplicationContext parent)throws BeansException {//调用父类的构造方法super(p…

Django Web架构:全面掌握Django模型字段(上)

Django Web架构 全面掌握Django模型字段&#xff08;上&#xff09; - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article…

【机器人最短路径规划问题(栅格地图)】基于蚁群算法求解

代码获取方式&#xff1a;QQ&#xff1a;491052175 或者 私聊博主获取 基于蚁群算法求解机器人最短路径规划问题的仿真结果 仿真结果 收敛曲线变化趋势 蚁群算法求解最优解的机器人运动路径 各代蚂蚁求解机器人最短路径的运动轨迹

二、TensorFlow结构分析(1)

目录 1、TF数据流图 1.1 TensorFlow结构分析 1.2 案例 2、图与TensorBoard 2.1 图结构 2.2 图相关操作 2.2.1 默认图 2.2.2 创建图 2.3 TensorBoard&#xff1a;可视化学习 2.3.1 数据序列化 - events文件 2.3.2 启动TensorBoard 2.4 OP 2.4.1 常见OP 2.4.2 指令…

20.图

图的基本概念 1.图的定义 由顶点和边组成的集合&#xff0c;G(V,E) 2.基本概念 邻接点&#xff1a; 对于无向图u v来说&#xff0c;uv互为邻接点 对于有向图u->v来说&#xff0c;v是u的邻接点&#xff0c;但u不是v的临界点 路径&#xff1a; 一个顶点到另一个顶点所经过的…

【漏洞复现】通天星CMSV6车载监控平台getImage任意文件读取漏洞

Nx01 产品简介 深圳市通天星科技有限公司&#xff0c;是一家以从事计算机、通信和其他电子设备制造业为主的企业。通天星车载视频监控平台软件拥有多种语言版本。应用于公交车车载视频监控、校车车载视频监控、大巴车车载视频监控、物流车载监控、油品运输车载监控、警车车载视…

【数据结构】_包装类与泛型

目录 1. 包装类 1.1 基本数据类型和对应的包装类 1.2 &#xff08;自动&#xff09;装箱和&#xff08;自动&#xff09;拆箱 1.2.1 装箱与拆箱 1.2.2 自动&#xff08;显式&#xff09;装箱与自动&#xff08;显式&#xff09;拆箱 1.3 valueOf()方法 2. 泛型类 2.1 泛…

bert 相似度任务训练完整版

任务 之前写了一个相似度任务的版本&#xff1a;bert 相似度任务训练简单版本,faiss 寻找相似 topk-CSDN博客 相似度用的是 0&#xff0c;1&#xff0c;相当于分类任务&#xff0c;现在我们相似度有评分&#xff0c;不再是 0,1 了&#xff0c;分数为 0-5&#xff0c;数字越大…

ChatGPT最新功能“Text To Speech (TTS,文本转语音)”详细解读!

大家好&#xff0c;我是木易&#xff0c;一个持续关注AI领域的互联网技术产品经理&#xff0c;国内Top2本科&#xff0c;美国Top10 CS研究生&#xff0c;MBA。我坚信AI是普通人变强的“外挂”&#xff0c;所以创建了“AI信息Gap”这个公众号&#xff0c;专注于分享AI全维度知识…

Windows环境MySQL全量备份+增量备份

一、环境准备 1.1.安装MySQL 在进行MySQL数据库备份和还原操作时&#xff0c;必须先提前安装好MySQL环境&#xff0c;且MySQL服务已成功开启 如果没有安装MySQL环境&#xff0c;可以参考博客&#xff1a;http://t.csdnimg.cn/h8bHl 如果已成功安装MySQL环境&#xff0c;打开…

Orbit 使用指南 02 | 在场景中生成原始对象| Isaac Sim | Omniverse

如是我闻&#xff1a; Orbit使用指南02将 深入探讨如何使用Python代码在Orbit中向场景生成各种对象&#xff08;或原始对象&#xff09;。一起探索如何生成地面平面、灯光、基本图形形状以及来自USD文件的网格。前置知识&#xff1a;如何生成空白场景&#xff0c;Orbit 使用指…

VUE实现Office文档在线编辑,支持doc/docx、xls/xlsx、ppt/pptx、pdf等

1.微软提供的在线Office预览&#xff08;只能预览&#xff0c;不能编辑&#xff09; https://view.officeapps.live.com/op/view.aspx?src服务器上文档地址&#xff08;http开头&#xff09; 2.国内在线Office方案&#xff1a; 腾讯文档、石墨文档、飞书 优势&#xff1a;跨…

paimon取消hive转filesystem

目录 概述实践关键配置spark sql 结束 概述 公司上一版本保留了 hive &#xff0c;此版优化升级后&#xff0c;取消 hive。 实践 关键配置 同步数据时&#xff0c;配置如下&#xff0c;将形成两个库 # ods库 CREATE CATALOG paimon WITH (type paimon,warehouse hdfs:///d…

CentOS配网报错:network is unreachable

常用命令&#xff1a; 打开&#xff1a; cd /etc/sysconfig/network-scripts/ 修改&#xff1a; vim ifcfg-ens33 打开修改&#xff1a; vim /etc/sysconfig/network-scripts/ifcfg-ens33 保存&#xff1a; 方法1&#xff1a;ESCZZ&#xff08;Z要大写&#xff09; 方…

熔断降级 spring事务

如果有事务处理&#xff0c;会先把事务的自动提交给关闭

Apache Flink连载(三十七):Flink基于Kubernetes部署(7)-Kubernetes 集群搭建-3

🏡 个人主页:IT贫道-CSDN博客 🚩 私聊博主:私聊博主加WX好友,获取更多资料哦~ 🔔 博主个人B栈地址:豹哥教你学编程的个人空间-豹哥教你学编程个人主页-哔哩哔哩视频 目录

32单片机基础:PWM驱动舵机,直流电机

PWM驱动舵机 接线图如上图所示。注意&#xff0c;舵机的5V 线不能接到面包板上的正极&#xff0c;面包板上的正极只有3.3V,是STM32提供的&#xff0c;所以要接到STLINK的5V, 我们如何驱动舵机呢&#xff1f;由之前我们介绍原理知道&#xff0c;要输出如下图对应的PWM波形才行…

202209 青少年软件编程等级考试Scratch二级真题

第 1 题 【 单选题 】 数字&#xff1a;1&#xff0c;2&#xff0c;3&#xff0c;4&#xff0c;6&#xff0c;9&#xff0c;13&#xff0c;19&#xff0c;28&#xff0c;...的下一项是多少&#xff1f; A&#xff1a;37 B&#xff1a;39 C&#xff1a;41 D&#xff1a;47 …

爱奇艺2023年营收319亿元:完善服务价值感知,重构影视新生态

近日&#xff0c;爱奇艺&#xff08;NASDAQ:IQ&#xff09;发布截至2023年12月31日未经审计的第四季度和全年财报&#xff0c;这份财报被外界评价为“爱奇艺交出的年度最佳业绩”。 财报显示&#xff0c;爱奇艺全年总营收319亿元&#xff0c;同比增长10%&#xff1b;非美国通用…

模拟器抓HTTP/S的包时如何绕过单向证书校验(XP框架)

模拟器抓HTTP/S的包时如何绕过单向证书校验&#xff08;XP框架&#xff09; 逍遥模拟器无法激活XP框架来绕过单向的证书校验&#xff0c;如下图&#xff1a; ​​ 解决办法&#xff1a; 安装JustMePlush.apk安装Just Trust Me.apk安装RE管理器.apk安装Xposedinstaller_逍遥64位…