Day06-角色管理-员工管理

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 1.编辑角色-进入行内编辑
  • 2.角色管理-行内编辑-数据缓存
  • 3.角色管理-编辑角色-确定取消
  • 4.角色管理-删除角色
  • 员工管理-页面结构
  • 6.员工管理-左侧树
  • 7.员工管理-选中首个节点
  • 8.员工管理-员工列表结构
  • 9.员工管理-获取员工数据
  • 10.员工管理-头像和聘用形式的处理
  • 11.员工管理-员工分页处理
  • 12.员工管理-员工模糊搜索


1.编辑角色-进入行内编辑

在这里插入图片描述
在这里插入图片描述

  • 获取数据之后针对每个数据定义标识-使用$set-代码位置(src/views/role/index.vue)
 // 针对每一行数据添加一个编辑标记
      this.list.forEach(item => {
        // item.isEdit = false // 添加一个属性 初始值为false
        // 数据响应式的问题  数据变化 视图更新
        // 添加的动态属性 不具备响应式特点
        // this.$set(目标对象, 属性名称, 初始值) 可以针对目标对象 添加的属性 添加响应式
        this.$set(item, 'isEdit', false)
      })
  • 点击编辑时,将当前行的标记isEdit设置为true(src/views/role/index.vue)
<el-table-column align="center" label="操作">
    <template>
        <!-- 非编辑状态 -->
        <el-button size="mini" type="text">分配权限</el-button>
        <el-button size="mini" type="text" @click="btnEditRow(row)">编辑</el-button>
        <el-button size="mini" type="text">删除</el-button>
    </template>
</el-table-column>
  • 点击编辑的方法-
data(){
 return{
 	row:[] 
 }
}
methods:{
  btnEditRow(row){
  row.isEdit = true//改变行的编辑状态
}
}
  • 表格列中根据当前的isEdit标记-渲染结构
<el-table-column prop="name" align="center" width="200" label="角色">
  <template v-slot="{row}">
    <el-input v-if="row.isEdit" size="mini"></el-input> 
    <span v-else>{{row.name}}</span>
  </template>
</el-table-column>
<el-table-column prop="state" align="center" width="200" label="启用">
  <template v-slot="{row}">
    <el-switch v-if="row.isEdit"/>
    <span v-else>{{row.state === 1? '已启用':row.state === 0 ? "未启用" :"无"}}</span>
  </template>
</el-table-column>
<el-table-column align="center"  label="操作">
  <template v-slot="{row}">
    <template v-if="row.isEdit">
   		<el-button type="primary" size="mini" >
			确定
		</el-button>
		<el-button  size="mini" >
			取消
		</el-button>
    </template>
    <template v-else>
       <el-button size="mini" type="text">分配权限</el-button>
        <el-button size="mini" type="text" @click="btnEditRow(row)">编辑</el-button>
        <el-button size="mini" type="text">取消</el-button>
     </template>
    <span v-else>{{row.name}}</span>
  </template>
</el-table-column>
  • $set的应用
  • this.$set(目标对象,属性名称,初始值)
  • 等价于Vue.set(目标对象,属性名称,初始值)
  • 往响应式对象中添加一个属性,并确保这个新属性同样是响应式的,且触发视图更新。

2.角色管理-行内编辑-数据缓存

  • 原因
  • 因为编辑时,可以取消回滚到之前的状态,所以编辑时的数据是临时的数据

在这里插入图片描述

  • editRow的数据是针对当前行的数据做了一份拷贝,针对这个拷贝,可以修改
  • 初始化时缓存数据(src/views/role/index.vue)
 this.list.forEach(item => {
        // item.isEdit = false//添加一个属性,初始值为false
        // 数据响应式问题 数据变化 视图更新
        // 添加的动态属性 不具备响应式特点
        // this.$set(目标对象,属性名称,初始值) 可以针对目标对象 添加的属性 添加响应式
        this.$set(item, 'isEdit', false)
        this.$set(item,'editRow',{
          name:item.name,
          state:item.state,
          description:item.description
        })
        console.log(item['isEdit']);
      })
  • 点击编辑时更新缓存数据-代码位置(src/views/role/index.vue)
btnEditRow(row) {
      row.isEdit = true // 改变行的编辑状态
      // 更新缓存数据
      row.editRow.name = row.name
      row.editRow.state = row.state
      row.editRow.description = row.description
}
  • 将编辑时的表单双向绑定缓存数据-代码位置(src/views/role/index.vue)
 <el-table :data="list">
        <!-- 列 -->
        <el-table-column prop="name" align="center" width="200" label="角色">
          <template v-slot="{row}">
            <!-- 条件判断 -->
            <el-input v-if="row.isEdit" v-model="row.editRow.name" size="mini"></el-input>
            <span v-else>{{ row.name }}</span>
          </template>
        </el-table-column>
        <el-table-column prop="state" align="center" width="200" label="启用">
          <!-- 自定义列结构 -->
          <template v-slot="{row}">
            <!-- 开 1 关0 -->
            <el-switch v-if="row.isEdit" v-model="row.editRow.state" :active-value="1" :inactive-value="0"></el-switch>
            <span v-else>{{ row.state === 1 ?'已启用':row.state === 0 ?"未启用":'无' }}</span>
          </template>
        </el-table-column>
        <el-table-column prop="description" align="center" label="描述">
          <template v-solt="{row}">
            <el-input v-if="row.isEdit" v-model="row.editRow.description" type="textarea"></el-input>
            <span v-else>{{ row.description }}</span>
          </template>
        </el-table-column>>
        <el-table-column align="center" label="操作">
          <!-- 操作按钮 -->
          <template v-slot="{row}">
            <template v-if="row.isEdit">
              <!-- 编辑状态 -->
              <el-button type="primary" size="mini">确定</el-button>
              <el-button size="mini">
                取消
              </el-button>
            </template>
            <template v-else>
              <!-- 非编辑状态 -->
              <el-button size="mini" type="text">分配权限</el-button>
              <el-button size="mini" @click="btnEditRow(row)" type="text">编辑</el-button>
              <el-button size="mini" type="text">删除</el-button>
            </template>
          </template>
        </el-table-column>
      </el-table>

3.角色管理-编辑角色-确定取消

在这里插入图片描述

  • 更新角色信息的请求api(src/api/role.js)
export function updateRole(data){
  return request({
    url:`/sys/role/${data.id}`,
    method:'put',
    data 
  })
}
  • 确定方法
 <!-- 编辑状态 -->
              <el-button type="primary" size="mini" @click="btnEditOK(row)">确定</el-button>
              <el-button size="mini">
                取消
              </el-button>
 async btnEditOK(row) {
      if (row.editRow.name && row.editRow.description) {
        //下一步操作 调用更新请求接口
        const result = await updateRole(
	        { 
	        ...row.editRow,
	         id: row.id 
	         }
         )
        //更新成功提示
        this.$message.success('更新角色成功')
        //更新显式数据 退出编辑状态
        //row.name = row.editRow.name//eslint的校验 误判
        //Object.assign(target,source)
        Object.assign(row, {
          ...row.editRow,
          isEdit: false//退出编辑模式

        })//规避eslint的误判
      }else{
        this.$message.warning('角色和描述不能为空')
      }
    }
  • 更新成功,要把缓存数据回显到页面上,并且关闭编辑模式
  • 取消方法
<el-button size="mini" @click="row.isEdit = false">取消</el-button>

4.角色管理-删除角色

在这里插入图片描述

  • 删除角色的api(src/api/role.js)
export function delRole(id){
  return request({
    url:`/sys/role/${id}`,
    method:'delte' 
  })
}
  • 在删除位置加入气泡框-代码位置(src/views/role/index.vue)
  <!-- 非编辑状态 -->
              <el-button size="mini" type="text">分配权限</el-button>
              <el-button size="mini" @click="btnEditRow(row)" type="text"
                >编辑</el-button
              >
             
              <el-popconfirm trigger="hover"
                title="确定删除吗?"
                @onConfirm="confirmDel(row.id)"
              >
                <el-button
                  slot="reference" 
                  style="margin-left: 10px"
                  size="mini"  type="text"
                  >删除</el-button
                >
              </el-popconfirm>
  • 删除方法-代码位置(src/views/role/index.vue)
async confirmDel(id){
  await delRole(id)//后端删除
  this.$message.success('删除成功')
  //如果删除的是最后一个
  if(this.list.length === 1){
   return this.pageParams.page--
   this.getRoleList()
   }
}

员工管理-页面结构

在这里插入图片描述
在这里插入图片描述

  • 基本的页面结构-代码位置(src/views/employee/index.vue)
 <div class="app-container">
      <div class="left">
        <el-input> </el-input>
        <!-- 树形组件 -->
      </div>
      <div class="right">
        <el-row class="opeate-tools" type="flex" justify="end">
          <el-button type="primary" size="mini">添加员工</el-button>
          <el-button size="mini">excel导入</el-button>
          <el-button size="mini">excel导出</el-button>
        </el-row>
        <!-- 表格组件 -->
        <!-- 分页 -->
      </div>
    </div>
    <style scoped lang="scss">
.app-container {
  background: #fff;
  display: flex;
  .left {
    width: 280px;
    padding: 20px;
    border-right: solid 1px #eaee64;
  }
  .right {
    flex: 1;
    padding: 20px;
    .opeate-tools {
      margin: 10px;
    }
    .username {
      height: 30px;
      width: 30px;
      line-height: 30px;
      text-align: center;
      border-radius: 50%;
      color: #fff;
      background: #04c9be;
      font-size: 12px;
      display: inline-block;
    }
  }
}
</style>

6.员工管理-左侧树

在这里插入图片描述

  • 树组件需要的数据-代码位置(src/views/employee/index.vue)
 data() {
    return {
      depts:[],//组织数据
      defaultProps:{
        label:'name',
        children:'children'
      }
    };
  },
  • 树形组件-代码位置(src/views/employee/index.vue)
<el-input> </el-input>
        <!-- 树形组件 -->
        <el-tree :data="depts" :props="defaultProps" default-expand-all expand-on-click-node="false" highlight-current></el-tree>
  • 初始化时加载数据转化树形-(src/views/employee/index.vue)
 methods: {
    async getDepartment() {
      //递归将列表转化成树
      const result = this.getDepartment();
      console.log(result);
      this.depts = transListToTreeData(await getDepartment(), 0);
    },
  },

7.员工管理-选中首个节点

在这里插入图片描述

  • 在data中声明一个记录id的参数-代码位置(src/views/employee/index.vue)
data(){
 return{
   //存查询参数
   queryParams:{
     departmentId:null
    }
  }
}
  • 因为后面的查询会有很多查询条件,到时候查询条件都会聚合到一起,所以使用一个公共的对象来管理更方便和合适
  • 初始化时首个id节点,并且选中-代码位置(src/views/employee/index.vue)
data () {
  return  {
    // 存储查询参数
      queryParams: {
        departmentId: null
      }
  }
}
  • 初始化时首个id节点,并且选中-代码位置(src/views/employee/index.vue)
methods:{
 async getDepartment(){
   this.depts = transListToTreeData(await getDepartment(),0)
   this.queryParams.departmentId = this.depts[0].id
   this.$nextTick(()=>{
     this.$refs.deptTree.setCurrentKey(this.queryParams.departmentId)
    })
  }
}

-监听树组件的节点切换事件-代码位置(src/views/employee/index.vue)

   <el-tree ref="deptTree"
          :data="depts"
          :props="defaultProps"
          default-expand-all
          expand-on-click-node="false"
          highlight-current
          @current-change="selectNode"
        ></el-tree>
  • 里需要明白,需要给定node-key属性,否则setCurrentKey方法不知道设置的是哪个字段的值
  • 切换节点时再次记录id-代码位置(src/views/employee/index.vue)
 selectNode(node){
      this.queryParams.departmentId = node.id
    }

8.员工管理-员工列表结构

  • 右侧列表页面结构-代码位置(src/views/employee/index.vue)
<el-table>
    <el-table-column align="center" label="头像" />
    <el-table-column label="姓名" />
    <el-table-column label="手机号" sortable />
    <el-table-column label="工号" sortable />
    <el-table-column label="聘用形式" />
    <el-table-column label="部门" />
    <el-table-column label="入职时间" sortable />
    <el-table-column label="操作" width="280px">
          <template>
              <el-button size="mini" type="text">查看</el-button>
              <el-button size="mini" type="text">角色</el-button>
              <el-button size="mini" type="text">删除</el-button>
          </template>
    </el-table-column>
</el-table>
<!-- 分页 -->
<el-row style="height: 60px" align="middle" type="flex" justify="end">
    <el-pagination
        layout="total,prev, pager, next"
        :total="1000"
     />
</el-row>

9.员工管理-获取员工数据

在这里插入图片描述

  • 获取员工数据的API-代码位置(src/api/employee.js)
export function getEmployeeList(params) {
  return request({
    url: '/sys/user',
    params // 地址参数 查询参数
  })
}
  • 声明一个list数据进行接受list-代码位置(src/views/employee/index.vue)
data () {
  return {
    list: []
  }
}
  • 初始化后获取右侧表格数据-代码位置(src/views/employee/index.vue)
methods: {
    async getDepartment() {
      // 递归方法 将列表转化成树形
      // let result = await getDepartment()
      this.depts = transListToTreeData(await getDepartment(), 0)
      this.queryParams.departmentId = this.depts[0].id
      // 设置选中节点
      // 树组件渲染是异步的 等到更新完毕
      this.$nextTick(() => {
        // 此时意味着树渲染完毕
        this.$refs.deptTree.setCurrentKey(this.queryParams.departmentId)
      })
      // 这个时候参数 记录了id
      this.getEmployeeList()
    },
    // 获取员工列表的方法
    async getEmployeeList() {
      const { rows } = await getEmployeeList(this.queryParams)
      this.list = rows
    }
  }
  • 切换节点时,获取右侧表格数据-代码位置(src/views/employee/index.vue)
 async getDepartment() {
      //递归将列表转化成树
      const result = this.getDepartment();
      console.log(result);
      this.depts = transListToTreeData(await getDepartment(), 0);
      this.queryParams.departmentId = this.depts[0].id
      //设置选中节点
      //树组件渲染是异步的 等到更新完毕
      this.$nextTick(() => {
        this.$refs.deptTree.setCurrentKey(this.queryParams.departmentId)
      })
      //
      this.getEmployeeList()
    },
    selectNode(node) {
      this.queryParams.departmentId = node.id //重新记录参数
      this.getEmployeeList()
    },
    //获取员工列表
    async getEmployeeList(){
      const { rows } = await getEmployeeList(this.queryParams)
      this.list = rows;
    }
  • 绑定表格-代码位置(src/views/employee/index.vue)
<el-table :data="list">
          <el-table-column prop="staffPhoto" align="center" label="头像" />
          <el-table-column prop="username" label="姓名" />
          <el-table-column prop="mobile" label="手机号" sortable />
          <el-table-column prop="workNumber" label="工号" sortable />
          <el-table-column prop="formOfEmployment" label="聘用形式" />
          <el-table-column prop="departmentName" label="部门" />
          <el-table-column prop="timeOfEntry" label="入职时间" sortable />
          ...
</el-table>

10.员工管理-头像和聘用形式的处理

  • 头像的设置-代码位置(src/views/employee/index.vue)
 <el-table-column prop="staffPhoto" align="center" label="头像">
      <template v-slot="{ row }">
          <el-avatar v-if="row.staffPhoto" :src="row.staffPhoto" :size="30" />
          <span v-else class="username">{{ row.username?.charAt(0) }}</span>
      </template>
</el-table-column>
  • 聘用形式的处理-代码位置(src/views/employee/index.vue)
<el-table-column prop="formOfEmployment" label="聘用形式">
    <template v-slot="{ row }">
        <span v-if="row.formOfEmployment === 1">正式</span>
        <span v-else-if="row.formOfEmployment === 2">非正式</span>
        <span v-else></span>
    </template>
</el-table-column>

11.员工管理-员工分页处理

在这里插入图片描述

  • 定义分页参数(src/views/employee/index.vue)
data(){
  return{
    queryParams:{
      departmentId:null,
      page:1,//当前页码
      paesize:10 
    },
    total:0,//记录员工的总数
   }
}
  • 绑定分页参数
<el-pagination
            layout="total,prev, pager, next"
            :total="total"
            :current-page="queryParams.page"
            :page-size="queryParams.pagesize"
            @current-change="changePage"
  />
  • 切换页码事件(src/views/employee/index.vue)
changePage(newPage){
  this.queryParams.page = newPage //赋值新页码
  this.getEmployeeList()//查询数据
}
  • 切换部门时,查询第一页数据(src/views/employee/index.vue)
selectNode(node){
	this.queryParams.page = 1;//设置第一页
}

12.员工管理-员工模糊搜索

  • 设置模糊搜索的参数字段(src/views/employee/index.vue)
 queryParams: {
        departmentId: null,
        page:1,//当前页码
        pageSize:10,
        keyword:''//模糊搜索字段
      },
  • 双向绑定input输入框,监听值改变事件
<el-input v-model="queryParams.keyword" prefix-icon="el-icon-search" size="small" placeholder="输入员工姓名全员搜索" @input="changeValue" /> 
  • input事件只要内容发生变化就会触发,change事件是离开焦点触发
  • 值改变查询数据-防抖
 changeValue() {
      // 单位时间内只执行最后一次
      // this的实例上赋值了一个timer的属性
      clearTimeout(this.timer) // 清理上一次的定时器
      this.timer = setTimeout(() => {
        this.queryParams.page = 1
        this.getEmployeeList()
      }, 300)
}

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

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

相关文章

ubuntu虚拟机安装samba server实现windows访问虚拟机文件

1. ubuntu下安装samba 1.1 安装samba sudo apt install net-tools # 不能使用ifconfig需要先安装net-tools sudo apt-get install samba1.2 配置samba用户 sudo smbpasswd -a guomq # 新增用户guomq&#xff0c;新增的时候需要设置密码&#xff0c;我们根据提示设置即可修改…

Jmeter+Ant+Git+Jenkins持续集成介绍

一 简介 1.什么是ant? ant是构建工具 2.什么是构建 概念到处可查到&#xff0c;形象来说&#xff0c;你要把代码从某个地方拿来&#xff0c;编译&#xff0c;再拷贝到某个地方去等等操作&#xff0c;当然不仅于此&#xff0c;但是主要用来干这个 3.ant的好处 跨平台 -…

程序员学长 | PyCaret,一个超强的 python 库

本文来源公众号“程序员学长”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;PyCaret&#xff0c;一个超强的 python 库 今天给大家分享一个超强的 python 库&#xff0c;PyCaret。 https://github.com/pycaret/pycaret 简介 …

一文看尽:各大数据公司和 AI 结合进展

一、前言 前面给大家梳理了一下大数据领域领先厂商 snowflake 和 databricks 的最新进展&#xff0c;还挺受欢迎&#xff0c;都是大几千的阅读量。没有看过的可以翻看下面的链接&#xff1a; 大模型时代最懂数据的公司 databricks snowflake 不再是个数据仓库公司了 应该说…

高效应对网络攻击,威胁检测响应(XDR)平台如何提升企业应急响应能力

在数字化时代&#xff0c;企业面临的网络攻击威胁持续增加&#xff0c;如恶意软件、勒索软件、钓鱼攻击、DDoS攻击等。这些威胁不仅危及企业数据安全、系统稳定&#xff0c;还损害了品牌形象和市场信任。随着云计算、大数据、物联网的广泛应用&#xff0c;企业网络攻击面扩大&a…

【2024_CUMCM】TOPSIS法(优劣解距离法)

目录 引入 层次分析法的局限性 简介 例子 想法1 想法2 运用实际分数进行处理 想法3 问题 扩展问题&#xff1a;增加指标个数 极大型指标与极小型指标 统一指标类型-指标正向化 标准化处理 计算公式 计算得分 对原公式进行变化 升级到m个指标和n个对象 代码 …

Python酷库之旅-第三方库Pandas(014)

目录 一、用法精讲 34、pandas.DataFrame.to_parquet函数 34-1、语法 34-2、参数 34-3、功能 34-4、返回值 34-5、说明 34-6、用法 34-6-1、数据准备 34-6-2、代码示例 34-6-3、结果输出 35、pandas.read_sql_table函数 35-1、语法 35-2、参数 35-3、功能 35-4…

防御笔记第四天(持续更新)

1.状态检测技术 检测数据包是否符合协议的逻辑顺序&#xff1b;检查是否是逻辑上的首包&#xff0c;只有首包才会创建会话表。 状态检测机制可以选择关闭或则开启 [USG6000V1]firewall session link-state tcp ? check Indicate link state check [USG6000V1]firewall ses…

Rejetto HFS 服务器存在严重漏洞受到攻击

AhnLab 报告称 &#xff0c;黑客正在针对旧版本的 Rejetto HTTP 文件服务器 (HFS) 注入恶意软件和加密货币挖矿程序。 然而&#xff0c;由于存在错误&#xff0c; Rejetto 警告用户不要使用 2.3 至 2.4 版本。 2.3m 版本在个人、小型团队、教育机构和测试网络文件共享的开发…

MySQL高级----详细介绍MySQL中的锁

概述 锁是计算机协调多个进程或线程并发访问某一资源的机制&#xff0c;为了解决数据访问的一致性和有效性问题。在数据库中&#xff0c;除传统的计算资源(CPU、RAN、I/O&#xff09;的争用以外&#xff0c;数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、…

将Hyper-V虚拟机与主机共享网络

Hyper-V 网络设置 目标 将Hyper-V虚拟机网络配置为与主机使用同一网络&#xff0c;并确保主机网络连接不受影响。 前提条件 主机上已安装Hyper-V已创建Hyper-V虚拟机 步骤 1. 配置主机网络共享 打开 控制面板 -> 网络和 Internet -> 网络连接。右键点击 WIAN,选择…

顶刊中的“水”刊!录取率>90%,十投九中,含金量高,近期1个月就录用!

本周投稿推荐 SCI • 能源科学类&#xff0c;1.5-2.0&#xff08;25天来稿即录&#xff09; • CCF推荐&#xff0c;4.5-5.0&#xff08;2天见刊&#xff09; • 生物医学制药类&#xff08;2天逢投必中&#xff09; EI • 各领域沾边均可&#xff08;2天录用&#xff09…

游戏AI的创造思路-技术基础-情感计算(1)

游戏中的AI也是可以和你打情感牌的哦&#xff0c;不要以为NPC是没有感情的&#xff0c;不过&#xff0c;不要和NPC打过多的情感牌&#xff0c;你会深陷其中无法自拔的~~~~~~ 目录 1. 情感计算算法定义 2. 发展历史 3. 公式和函数 3.1. 特征提取阶段 TF-IDF&#xff08;词频…

vue 自定义(hook)--(模块化)

文章目录 定义示例代码 定义 什么是hook&#xff1f;—— 本质是一个函数&#xff0c;把setup函数中使用的Composition API进行了封装&#xff0c;类似于vue2.x中的mixin。 自定义hook的优势&#xff1a;复用代码, 让setup中的逻辑更清楚易懂。 示例代码 useSum.ts中内容如下…

Linux基础指令解析+项目部署环境

文章目录 前言基础指令部署项目环境总结 前言 Linux的魅力在于其强大的可定制性和灵活性&#xff0c;这使得它成为了众多开发者和运维人员的首选工具。然而&#xff0c;Linux的指令系统庞大而复杂&#xff0c;初学者往往容易迷失其中。因此&#xff0c;本文将带领大家走进Linu…

第三期书生大模型实战营 第1关 Linux 基础知识

第三期书生大模型实战营 第1关 Linux 基础知识 第三期书生大模型实战营 第1关 Linux 基础知识InternStudio开发机创建SSH密钥配置通过本地客户端连接远程服务器通过本地VSCode连接远程服务器运行一个Python程序总结 第三期书生大模型实战营 第1关 Linux 基础知识 Hello大家好&a…

设计分享—国外后台界面设计赏析

国外后台界面设计将用户体验放在首位&#xff0c;通过直观易懂的布局和高效的交互设计&#xff0c;提升用户操作效率和满意度。 设计不仅追求美观大方&#xff0c;还注重功能的实用性和数据的有效展示&#xff0c;通过图表和图形化手段使数据更加直观易懂。 采用响应式布局&a…

C++的介绍与认识

目录 前言 1.什么是C 2.C的发展历史 3.C参考文档 4.C重要性 4.1C特点 4.2编程语言排行榜 4.3 C的应用领域 5.C学习指南 1. 基础知识 2. 面向对象编程&#xff08;OOP&#xff09; 3. 泛型编程 4. 标准库&#xff08;STL&#xff09; 结束语 前言 学习了C语言的知识…

LINUX命令行curl指令与python内置urllib模块

urllib是python御用的易用的轻便模块&#xff0c;curl是Linux功能强大的命令行工具&#xff0c;都是参与Web的利器。 (笔记模板由python脚本于2024年07月10日 18:41:12创建&#xff0c;本篇笔记适合喜欢Python和Linux的coder翻阅) 【学习的细节是欢悦的历程】 Python 官网&…

【AI大模型】检索增强生成(RAG)模型在企业中的应用

彩蛋 ChatGPT4相比于ChatGPT3.5,有着诸多不可比拟的优势&#xff0c;比如图片生成、图片内容解析、GPTS开发、更智能的语言理解能力等&#xff0c;但是在国内使用GPT4存在网络及充值障碍等问题&#xff0c;如果您对ChatGPT4.0感兴趣&#xff0c;可以私信博主为您解决账号和环境…