根据后端返回下拉请求地址,前端动态请求拿到下拉数据渲染

news2025/1/16 5:41:55

完整代码如下:

<template>

  <!-- 资源列表页 -->

  <div>

    <div>

      <i

        @click="$router.go(-1)"

        style="

          color: #409eff;

          cursor: pointer;

          margin-right: 5px;

          font-size: 18px;

        "

        class="el-icon-back"

      ></i

      >{{ getCurrentPageTitle }}

    </div>

    <br />

    <el-row class="contentTop">

      <el-col :span="12">

        <el-button type="primary" size="mini" @click="doAdd">新建</el-button>

        <el-button

          size="mini"

          @click="

            drawerImportant = true;

            active = 0;

            currentFile = null;

          "

          >导入</el-button

        >

        <!-- <el-button size="mini">批量更新</el-button>

        <el-button size="mini">删除</el-button> -->

        <el-button size="mini" @click="doExport">导出</el-button>

        <el-button size="mini" @click="doExportTemplate">导出模板</el-button>

      </el-col>

      <el-col :span="10">

        <el-input

          placeholder="请输入内容"

          v-model="inputValue"

          class="input-with-select"

          size="mini"

          clearable

        >

          <el-select

            v-model="selectValue"

            slot="prepend"

            style="width: 120px"

            placeholder="请选择"

            clearable

            @change="changeSelect"

          >

            <el-option

              :label="item.label"

              :value="item.value"

              v-for="item in searchList"

              :key="item.value"

            ></el-option>

          </el-select>

          <el-button

            slot="append"

            icon="el-icon-search"

            @click="doSearch"

          ></el-button>

        </el-input>

      </el-col>

      <el-col :span="0.5">

        <el-button

          icon="el-icon-setting"

          size="mini"

          @click="doSetting"

        ></el-button>

      </el-col>

    </el-row>

    <br />

    <el-row>

      <!-- @cell-click="doClickCell" -->

      <el-table

        :data="tableInfo.list"

        size="mini"

        @selection-change="handleSelectionChange"

        fit

        :stripe="true"

        :row-key="rowKey"

        ref="multipleTable"

        max-height="500"

        border

        id="tableId"

        @sort-change="sortChange"

      >

        <!-- <el-table-column

          type="selection"

          :reserve-selection="true"

          width="55"

        ></el-table-column> -->

        <el-table-column

          v-for="(item, index) in tableInfo.columns"

          v-if="!item.hide"

          :prop="item.name"

          :label="item.label"

          :key="index"

          :show-overflow-tooltip="true"

          sortable="custom"

        >

          <!-- <template slot-scope="scope">

            <el-button

              v-if="item.name == 'example'"

              type="text"

              @click="doClickCell(scope.row)"

              >{{ scope.row[item.name] }}</el-button

            >

            <span v-else>{{ scope.row[item.name] }}</span>

          </template> -->

        </el-table-column>

        <el-table-column fixed="right" label="操作" width="180">

          <template slot-scope="scope">

            <el-button @click="doClickCell(scope.row)" type="text" size="small"

              >详情</el-button

            >

            <el-button

              @click.stop="deleteRow(scope.row.id)"

              type="text"

              size="small"

              >删除</el-button

            >

          </template>

        </el-table-column>

      </el-table>

      <div style="text-align: center">

        <el-pagination

          @size-change="handleSizeChange"

          @current-change="handleCurrentChange"

          :current-page="paramsPage.pageNum"

          :page-sizes="[10, 20, 30, 50, 100]"

          :page-size="paramsPage.pageSize"

          layout="total, sizes, prev, pager, next, jumper"

          :total="tableInfo.total"

        ></el-pagination>

      </div>

    </el-row>

    <el-drawer

      title="列表显示属性配置"

      :visible.sync="drawer"

      direction="rtl"

      size="45%"

    >

      <el-transfer

        style="text-align: left; display: inline-block"

        v-model="transferValue"

        filterable

        :left-default-checked="[]"

        :right-default-checked="[]"

        :render-content="renderFunc"

        :titles="['未选属性', '已选属性']"

        :format="{

          noChecked: '${total}',

          hasChecked: '${checked}/${total}',

        }"

        :props="{

          key: 'name',

          label: 'label',

        }"

        @change="handleChange"

        :data="dataList"

      >

      </el-transfer>

      <br />

      <br />

      <div style="padding: 0 20px">

        <el-button type="primary" size="small" @click="doSettingConfirm"

          >应用</el-button

        >

        <el-button size="small" @click="drawer = false">取消</el-button>

        <el-button style="float: right" size="small" @click="doRest"

          >还原默认</el-button

        >

      </div>

    </el-drawer>

    <el-drawer

      title="创建"

      :visible.sync="drawerAdd"

      direction="rtl"

      size="30%"

    >

      <div style="padding-left: 20px">

        <el-form

          label-position="top"

          label-width="80px"

          :model="formLabelAlign"

        >

          <el-collapse

            v-model="activeNames"

            v-for="(item, index) in modelList"

            :key="index"

          >

            <el-collapse-item :title="item.name" :name="index">

              <el-row :gutter="40" v-for="(v, i) in item.infoList" :key="i">

                <el-col :span="20">

                  <el-form-item :label="v.label">

                    <el-input

                      v-if="v.typeValue == 'input'"

                      v-model="formLabelAlign[v.name]"

                      placeholder="请输入"

                      style="width: 570px"

                    ></el-input>

                    <el-input

                      v-else-if="v.typeValue == 'number'"

                      type="number"

                      v-model="formLabelAlign[v.name]"

                      placeholder="请输入"

                      style="width: 570px"

                    ></el-input>

                    <el-date-picker

                      v-else-if="v.typeValue == 'date'"

                      value-format="yyyy-MM-dd"

                      type="date"

                      v-model="formLabelAlign[v.name]"

                      placeholder="请输入"

                      style="width: 570px"

                    ></el-date-picker>

                    <el-date-picker

                      v-else-if="v.typeValue == 'time'"

                      value-format="yyyy-MM-dd HH:mm:ss"

                      type="datetime"

                      v-model="formLabelAlign[v.name]"

                      placeholder="请输入"

                      style="width: 570px"

                    ></el-date-picker>

                    <el-select

                      v-else-if="

                        v.typeValue == 'select' &&

                        v[`valueAttribute${i}`] &&

                        v[`valueAttribute${i}`].length > 0

                      "

                      v-model="formLabelAlign[v.name]"

                      clearable

                      style="width: 570px"

                    >

                      <el-option

                        v-for="w in v[`valueAttribute${i}`]"

                        :key="w.key"

                        :label="w.value"

                        :value="w.key"

                      >

                      </el-option>

                    </el-select>

                    <el-cascader

                      v-else-if="

                        v.typeValue == 'isCascade' &&

                        v[`valueAttribute${i}`] &&

                        v[`valueAttribute${i}`].length > 0

                      "

                      v-model="formLabelAlign[v.name]"

                      :options="v[`valueAttribute${i}`]"

                      :props="propsCascader"

                      @change="handleChangeCas"

                    ></el-cascader>

                  </el-form-item>

                </el-col>

              </el-row>

            </el-collapse-item>

          </el-collapse>

          <div class="bottomButton">

            <el-button type="primary" @click="doConfirm">提交</el-button>

            <el-button @click="drawerAdd = false">取消</el-button>

          </div>

        </el-form>

      </div>

    </el-drawer>

    <el-drawer

      title="批量导入"

      :visible.sync="drawerImportant"

      direction="rtl"

      size="45%"

    >

      <div style="padding-left: 20px">

        <el-steps :active="active" finish-status="success" align-center>

          <el-step title="上传文件"></el-step>

          <el-step title="选择关联模型"></el-step>

        </el-steps>

        <div style="padding-left: 20px">

          <div v-if="active == 0">

            <div

              style="

                margin: 20px 0;

                background: rgb(255, 244, 226);

                border: 1px solid rgb(255, 223, 172);

              "

            >

              <i style="color: rgb(255, 156, 1)" class="el-icon-info"></i>

              说明:导入编辑需要先导出需要修改的实例,并完成编辑修改后才能进行导入编辑操作

            </div>

            <el-upload

              class="upload-demo"

              drag

              action

              multiple

              :http-request="uploadFiles"

            >

              <i class="el-icon-upload"></i>

              <div class="el-upload__text">

                将文件拖到此处,或<em>点击上传</em>

              </div>

              <div class="el-upload__tip" slot="tip">

                只能上传jpg/png文件,且不超过500kb

                <el-button

                  type="primary"

                  icon="el-icon-download"

                  size="mini"

                  @click="downloadTemplate"

                  >下载模板</el-button

                >

              </div>

            </el-upload>

          </div>

          <div style="margin: 20px 0" v-if="active == 1">

            <el-checkbox v-model="checked">是否导入关联的模型实例</el-checkbox>

          </div>

          <div style="margin-top: 20px">

            <el-button

              v-if="active == 0"

              type="primary"

              :disabled="!currentFile"

              @click="active = 1"

              >下一步</el-button

            >

            <el-button v-if="active == 1" @click="active = 0">上一步</el-button>

            <el-button v-if="active == 1" type="primary" @click="doImportant"

              >开始导入</el-button

            >

            <el-button @click="drawerImportant = false">取消</el-button>

          </div>

        </div>

      </div>

    </el-drawer>

  </div>

</template>

<script>

import { mapGetters, mapMutations } from "vuex";

import tableCell from "./tableCell";

import { unique } from "@/utils/index";

import {

  resourceList,

  deleteResource,

  queryResource,

  findAllModel,

  getAddress,

  exportTemplate,

  uploadResource,

  exportResource,

  exportResourceTemplate,

  addResource,

  batchUpdateField,

  findAll,

  querySelect,

} from "@/api/cmdb/model";

export default {

  data() {

    return {

      inputValue: "",

      select: "",

      valueCade: [],

      selectValue: "",

      drawer: false,

      drawerAdd: false,

      drawerImportant: false,

      checked: false,

      active: 0,

      activeNames: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12],

      multipleSelection: [],

      searchList: [],

      modelList: [],

      currentArgs: [],

      formInline: {},

      formLabelAlign: {},

      currentFile: null,

      tableInfo: {

        columns: [],

        list: [],

        total: 0,

      },

      paramsPage: {

        pageNum: 1,

        pageSize: 10,

      },

      dataList: [], // 所有字段数据

      selectFieldList: [],

      transferValue: [], // 右侧数据

      renderFunc(h, option) {

        return (

          <span>

            {/* {option.key} - {option.label} */}

            {option.label}

          </span>

        );

      },

      propsCascader: {

        value: "key",

        label: "value",

        children: "child",

      },

    };

  },

  computed: {

    ...mapGetters(["getCurrentPageTitle", "getActiveModel"]),

  },

  // watch: {

  //   $route: {

  //     handler(to, from) {

  //       this.$set(this.tableInfo, "columns", tableCell[to.params.id]);

  //       this.paramsPage.pageSize = 10;

  //       this.paramsPage.pageNum = 1; //重置页面

  //     },

  //     immediate: true,

  //   },

  // },

  mounted() {

    this.getList();

    this.getSearchList();

    this.getFields();

  },

  methods: {

    ...mapMutations(["setDetailTitle", "setResourceId"]),

    // 当前模型详情查询(新建字段)

    getFields() {

      let params = {

        args: this.getActiveModel.uniqueId,

      };

      findAllModel(params)

        .then((res) => {

          if (res.code == 0) {

            this.modelList = res.data; // 当前模型下包含的分组

            this.modelList.forEach(v1 => {

              v1.infoList.forEach((v2,i2)=> {

                if(v2.typeValue == 'isCascade' || v2.typeValue == 'select') {

                  getAddress(v2.dateTypeValue,{}).then(res2 => {

                    v2[`valueAttribute${i2}`] = res2

                  })

                }

              })

            })

            // 列表字段显示隐藏

            let arr = [];

            res.data.forEach((v) => {

              arr.push(v.infoList);

            });

            this.dataList = arr.flat(); // 二维数组转一维

            // 右侧数据

            this.transferValue = this.dataList.map((v) => {

              if (v.show) {

                return v.name;

              }

            });

          } else {

            res.desc && this.$message.error(res.desc);

          }

        })

        .catch((err) => {

          err.desc && this.$message.error(err.desc);

        });

    },

    getList(id = "id", order = "", args) {

      let params = {

        currPage: this.paramsPage.pageNum,

        pageSize: this.paramsPage.pageSize,

        uniqueId: this.getActiveModel.uniqueId,

        args: args || [],

        sortName: id,

        sortValue: order == "descending" ? false : true, // true = ASC,false = DESC

      };

      resourceList(params)

        .then((res) => {

          if (res.code == 0) {

            this.tableInfo.columns = res.data.headers;

            this.tableInfo.list = res.data.bodyData.list;

            this.tableInfo.total = res.data.bodyData.total;

          } else {

            res.desc && this.$message.error(res.desc);

          }

        })

        .catch((err) => {

          err.desc && this.$message.error(err.desc);

        });

    },

    // 排序

    sortChange({ column, prop, order }) {

      // console.log(column, prop, order );

      this.getList(prop, order, []);

    },

    changeSelect(key) {

      this.currentKey = key;

    },

    // 按条件搜索

    doSearch() {

      // if (!this.currentKey) {

      //   return this.$message.warning("请选择需要查询的字段名称");

      // }

      let args = [

        {

          key: this.currentKey,

          value: this.inputValue,

          select: false, // true为下拉搜索,一般默认都是输入框

        },

      ];

      this.currentArgs = args;

      this.getList("id", "", this.inputValue ? args : []);

    },

    // 查询下拉

    getSearchList() {

      let params = {

        args: this.getActiveModel.uniqueId,

      };

      queryResource(params).then((res) => {

        if (res.code == 0) {

          this.searchList = res.data;

        }

      });

    },

    rowKey(row) {

      return row.id;

    },

    handleSizeChange(val) {

      this.paramsPage.pageSize = val;

      this.getList();

    },

    handleCurrentChange(val) {

      this.paramsPage.pageNum = val;

      this.getList();

    },

    //多选

    handleSelectionChange(val) {

      // console.log(val);

      this.multipleSelection = val;

    },

    doSetting() {

      this.drawer = true;

    },

    // 还原默认

    doRest() {

      this.dataList.forEach((v) => {

        v.createTime && delete v.createTime;

        v.updateTime && delete v.updateTime;

        // 第一次保存的设置true,其他都隐藏false

        if (v.showDefault) {

          v.show = true;

        } else {

          v.show = false;

        }

      });

      batchUpdateField(this.dataList)

        .then((res) => {

          if (res.code == 0) {

            this.drawer = false;

            this.getList();

            this.getFields();

            this.$message.success(res.desc);

          } else {

            this.drawer = false;

            res.desc && this.$message.error(res.desc);

          }

        })

        .catch((err) => {

          this.drawer = false;

          err.desc && this.$message.error(err.desc);

        });

    },

    // 字段显示配置--应用

    doSettingConfirm() {

      let arr = [];

      arr = this.selectFieldList.map((v) => {

        return v.showDefault;

      });

      // 如果包含true,说明保存过一次,如果不包含true,说明第一次保存,为还原默认设置数据

      if (arr.includes(true)) {

        // console.log('保存过一次');

      } else {

        // console.log('第一次保存');

        // 第一次保存-应用,右侧showDefault设为true

        this.selectFieldList.forEach((v1) => {

          this.transferValue.forEach((v2) => {

            if (v2 == v1.name) {

              v1.showDefault = true;

            }

          });

        });

      }

      batchUpdateField(this.selectFieldList)

        .then((res) => {

          if (res.code == 0) {

            this.drawer = false;

            this.getList();

            this.getFields();

            this.$message.success(res.desc);

          } else {

            this.drawer = false;

            res.desc && this.$message.error(res.desc);

          }

        })

        .catch((err) => {

          this.drawer = false;

          err.desc && this.$message.error(err.desc);

        });

    },

    handleChangeCas(val) {},

    handleChange(value, direction, movedKeys) {

      // console.log(value, direction, movedKeys);

      let arr = [];

      // value为右侧数据;左侧dataList为所有数据

      // 默认全部show设为false,右侧是选中的需要show设为true,否则就为false

      this.dataList.forEach((v1) => {

        v1.show = false;

        v1.createTime && delete v1.createTime;

        v1.updateTime && delete v1.updateTime;

      });

      this.dataList.forEach((v1) => {

        value.forEach((v2) => {

          if (v2 == v1.name) {

            v1.show = true;

            arr.push(v1);

          } else {

            arr.push(v1);

          }

        });

      });

      this.selectFieldList = unique(arr, "id"); // 根据id去重

    },

    doClickCell(row) {

      this.setDetailTitle(row.example);

      this.setResourceId(row.id);

      this.$router.push({ path: `/resource/detail` });

    },

    next() {

      this.active = 2;

    },

    deleteRow(id) {

      let that = this;

      let params = {

        uniqueId: this.getActiveModel.uniqueId,

        id: id,

      };

      that

        .$confirm("确认要删除这条数据?", "提示", {

          confirmButtonText: "确定",

          cancelButtonText: "取消",

          type: "warning",

        })

        .then(() => {

          deleteResource(params)

            .then((res) => {

              if (res.code == 0) {

                that.$message.success(res.desc);

                that.getList();

              } else {

                if (res.desc) {

                  that.$message.error(res.desc);

                }

              }

            })

            .catch((err) => {

              err.desc && that.$message.error(err.desc);

            });

        })

        .catch(() => {

          that.$message({

            type: "info",

            message: "已取消删除",

          });

        });

    },

    doAdd() {

      this.drawerAdd = true;

      this.formLabelAlign = {};

    },

    // 新建--提交

    doConfirm() {

      if (

        this.formLabelAlign.example_department &&

        this.formLabelAlign.example_department.length > 0

      ) {

        this.formLabelAlign.example_department =

          this.formLabelAlign.example_department.join();

      }

      let params = {

        uniqueId: this.getActiveModel.uniqueId,

        args: this.formLabelAlign,

      };

      addResource(params)

        .then((res) => {

          if (res.code == 0) {

            this.getList();

            this.drawerAdd = false;

            this.$message.success(res.desc);

          } else {

            res.desc && this.$message.error(res.desc);

          }

        })

        .catch((err) => {

          err.desc && this.$message.error(err.desc);

        });

    },

    getDownload(res) {

      const blob = new Blob([res]);

      // const fileName = res.headers["content-disposition"].split("=")[1];

      const fileName = this.getActiveModel.uniqueId;

      const elink = document.createElement("a");

      elink.download = window.decodeURIComponent(fileName);

      elink.style.display = "none";

      elink.href = URL.createObjectURL(blob);

      elink.setAttribute("download", `${fileName}.xlsx`); // 下载文件的名称及文件类型后缀

      document.body.appendChild(elink);

      elink.click();

      URL.revokeObjectURL(elink.href); // 释放URL 对象

      document.body.removeChild(elink);

    },

    // 下载模板

    downloadTemplate() {

      let params = {

        uniqueId: this.getActiveModel.uniqueId,

      };

      exportTemplate(params).then((res) => {

        this.getDownload(res);

      });

    },

    // 导出

    doExport() {

      let params = {

        uniqueId: this.getActiveModel.uniqueId,

        currPage: this.paramsPage.pageNum,

        pageSize: this.paramsPage.pageSize,

        args: this.currentArgs,

        titleList: this.multipleSelection.map((v) => v.id),

      };

      exportResource(params).then((res) => {

        this.getDownload(res);

      });

    },

    // 导出模板

    doExportTemplate() {

      let params = {

        uniqueId: this.getActiveModel.uniqueId,

      };

      exportResourceTemplate(params).then((res) => {

        this.getDownload(res);

      });

    },

    // 导入--上传

    uploadFiles(files) {

      const _file = files.file;

      this.currentFile = _file;

      // var formData = new FormData();

      // formData.append("file", _file);

      // formData.append("uniqueId", this.getActiveModel.uniqueId);

      // uploadResource(formData)

      //   .then((res) => {

      //     if (res.code == 0) {

      //       this.getList();

      //       this.drawerImportant = false;

      //       this.$message.success(res.desc);

      //     } else {

      //       res.desc && this.$message.error(res.desc);

      //     }

      //   })

      //   .catch((err) => {

      //     err.desc && this.$message.error(err.desc);

      //   });

    },

    // 开始导入

    doImportant() {

      var formData = new FormData();

      formData.append("file", this.currentFile);

      formData.append("uniqueId", this.getActiveModel.uniqueId);

      uploadResource(formData)

        .then((res) => {

          if (res.type == "application/json") {

            this.$message.success("导入成功");

            this.drawerImportant = false;

            this.getList();

          } else {

            this.drawerImportant = false;

            this.$message.error("导入失败");

          }

        })

        .catch((err) => {

          this.drawerImportant = false;

          this.$message.error("导入失败");

        });

    },

  },

};

</script>

<style scoped lang="scss">

.contentTop {

  display: flex;

  justify-content: space-between;

  align-items: center;

}

::v-deep .el-drawer__open .el-drawer.rtl {

  -webkit-animation: rtl-drawer-in 0.3s 1ms;

  animation: rtl-drawer-in 0.3s 1ms;

  width: 38% !important;

}

::v-deep .el-transfer-panel {

  height: 660px !important;

}

::v-deep .el-transfer-panel__list.is-filterable {

  height: 660px !important;

}

::v-deep .el-upload-dragger {

  width: 530px !important;

}

.bottomButton {

  position: sticky;

  bottom: 0;

  left: 0;

  margin-top: 10px;

}

</style>

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

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

相关文章

C++ 关键字 :using

在 C 庞大语法体系中&#xff0c; using 关键字十分的灵活多用&#xff0c;它可不简单。 除了常规的引入命名空间之外&#xff0c;它还可用于引入枚举类型枚举器、定义常规类型别名、模板类型别名等。在定义常规类型别名方面与C语言中的typedef、#define与之相似&#xff0c;但…

jupyter notebook中调整图片大小

截屏 ctrl V 这个目前只能保证是截屏大小&#xff0c;改变不了&#xff0c;要么之久 把图形缩小后再截图 感觉很模糊 png文件导入 markdown 代码1 <img src"./1.png" width250 height200>markdown 代码2 <img src"./1.png" width938 height…

文献速递:多模态深度学习在医疗中的应用--多模式婴儿脑分割技术:模糊引导深度学习

Title 题目 Multimodal Infant Brain Segmentation by Fuzzy-informed Deep Learning 多模式婴儿脑分割技术&#xff1a;模糊引导深度学习 01 文献速递介绍 日益普及的非侵入式婴儿脑磁共振图像&#xff08;MRI&#xff09;为准确理解脑主要发展轨迹的动态性提供了机会&…

普中STM32F103ZET6开发板让DS0和DS1两个LED同时亮

欢迎关注我👆,收藏下次不迷路┗|`O′|┛ 嗷~~ 目录 一.前言 二.代码 三.运行效果 一.前言 在这套stm32教程中,只教学了如何亮DS0,而没有教学如何亮DS1。 二.代码 main.c #include "stm32f10x.h"void Syst

一篇文章告诉你聚类算法的作用和怎么用聚类算法!建议收藏!(下篇)

EM聚类 EM聚类 基于概率分布对数据进行建模&#xff0c;通过迭代的期望和最大化步骤来估计模型参数&#xff0c;并将数据分为不同的聚类。EM聚类通常用于处理混合分布的数据&#xff0c;其中每个聚类被建模为一个概率分布。 原理介绍 EM聚类的核心思想是将数据集中的每个样本…

二分答案(区间范围)

D. Jumping Through Segments 输入数据 4 5 1 5 3 4 5 6 8 10 0 1 3 0 2 0 1 0 3 3 3 8 10 18 6 11 4 10 20 0 5 15 17 2 2 输出范围 7 0 5 13#include<bits/stdc.h> #define int long long using namespace std; typedef pair<char,int>PII; const int N2e510;…

应急响应-Windows-挖矿病毒

随着虚拟货币市场的繁荣&#xff0c;挖矿病毒已成为网络安全领域一大挑战。该类病毒利用计算机资源进行加密货币的挖掘&#xff0c;给个人用户和企业网络带来了严重的安全风险。本文将针对挖矿病毒的应急响应和防范措施进行分析和总结。 一.判断挖矿病毒 服务器突然发现CPU资…

树莓派发送指令控制FPGA板子上的流水灯程序

文章目录 前言一、树莓派简介二、整体实现步骤三、树莓派设置四、树莓派串口代码五、Verilog代码5.1 串口接收模块5.2 流水灯模块 六、quartus引脚绑定七、 运行效果总结参考 前言 ​ 本次实验的目的是通过树莓派和FPGA之间的串口通信&#xff0c;控制FPGA开发板上的小灯。实验…

OpenAI 发布新款大型语言模型 GPT-4o,带大家了解最新ChatGPT动态。

OpenAI 发布新款大型语言模型 GPT-4o 昨日OpenAI 举办了一场线上活动&#xff0c;正式发布了其最新研发的 AI 模型 GPT-4o&#xff0c;并详细介绍了该模型的强大功能和未来发展规划。此次发布标志着 AI 技术的重大突破&#xff0c;为用户提供了更加便捷、高效的 AI 工具&#…

css多种布局方式

css多种布局方式 简介标准流布局&#xff08;主要依赖margin\padding&#xff09;浮动布局&#xff08;float&#xff09;定位布局&#xff08;position&#xff09;弹性布局&#xff08;flex&#xff09;网格布局&#xff08;grid&#xff09;多列布局&#xff08;column&…

【论文阅读】<YOLOP: You Only Look Once for PanopticDriving Perception>

Abstract 全视驾驶感知系统是自动驾驶的重要组成部分。一个高精度的实时感知系统可以帮助车辆在驾驶时做出合理的决策。我们提出了一个全视驾驶感知网络&#xff08;您只需寻找一次全视驾驶感知网络&#xff08;YOLOP&#xff09;&#xff09;&#xff0c;以同时执行交通目标检…

7.STL中string的一些超常用函数 (附习题)

目录 1.find 2.atoi 3.to_string 4.getline 【leetcode 习题】 387.字符串中的第一个唯一字符 125. 验证回文串 1.find 1.查找第一次出现的目标字符串&#xff1a;说明&#xff1a;如果查找成功则输出查找到的第一个位置&#xff0c;否则返回-1&#xff1b; s1.find(s2…

嗨动PDF编辑器怎么删除pdf空白页?教程来啦!

嗨动PDF编辑器怎么删除pdf空白页&#xff1f;在日常的工作和学习中&#xff0c;PDF文件因其跨平台兼容性和稳定性而备受青睐。然而&#xff0c;在编辑PDF文件时&#xff0c;我们往往会遇到一些令人头疼的问题&#xff0c;其中最常见的就是空白页。空白页不仅浪费了宝贵的存储空…

ESP32-S3+86盒线控器方案,含开发时问题技术解答

随着智能家居产品越来越多&#xff0c;线控器应用也加大&#xff0c;86盒线控器跟智能吹风机联动&#xff0c;跟中央空调联动&#xff0c;下面讲下ESP32-S386盒线控器方案在开发中遇到的问题。 一、ESP32-S386盒线控器方案&#xff1a; 1、无需网关&#xff0c;可以直接连家里…

零基础10 天入门 Web3之第3天

10 天入门 Web3之第3天 什么是以太坊&#xff0c;以太坊能做什么&#xff1f;Web3 是互联网的下一代&#xff0c;它将使人们拥有自己的数据并控制自己的在线体验。Web3 基于区块链技术&#xff0c;该技术为安全、透明和可信的交易提供支持。我准备做一个 10 天的学习计划&…

Linux系统运行级别

Linux系统运行级别&#xff1a;linux系统共有7个运行级别&#xff0c;不同的级别运行的程序和功能都是不一样的而linux系统默认是运行在一个标准级别上&#xff0c;系统运行级别文件/etc/inittab 运行级别0&#xff1a;所有进程被终止&#xff0c;机器将有序的停止&#xff0c;…

SpringBootWeb 篇-深入了解请求响应(服务端接收不同类型的请求参数的方式)

&#x1f525;博客主页&#xff1a; 【小扳_-CSDN博客】 ❤感谢大家点赞&#x1f44d;收藏⭐评论✍ 文章目录 1.0 请求响应概述 1.1 简单参数 1.2 实体参数 2.3 数组集合参数 2.4 日期参数 2.5 json 参数 2.6 路径参数 3.0 完整代码 1.0 请求响应概述 当客户端发送不同的请求参…

【专利】一种日志快速分析方法、设备、存储介质

公开号CN116560938A申请号CN202310311478.5申请日2023.03.28 是我在超音速人工智能科技股份有限公司(833753) 职务作品&#xff0c;第一发明人是董事长夫妇&#xff0c;第二发明人是我。 ** 注意** &#xff1a; 内容比较多&#xff0c;还有流程图、界面等。请到 专利指定页面…

30-10y国债利差反转的必要条件

国君宏观表示&#xff0c;30-10y期限利差定价本质上是私人部门主动加杠杆的预期&#xff0c;央行购债与资本市场的正向反馈是可以期待的一种场景&#xff0c;而企业部门的被动加杠杆须以可持续的需求动能与盈利预期作为前提。 要点&#xff1a; 期限利差的本质&#xff1a;对长…

如何压缩图片大小?7个实用软件教你快速压缩图片大小

如何压缩图片大小&#xff1f;7个实用软件教你快速压缩图片大小 以下是七个实用的软件&#xff0c;可以帮助您快速压缩图片大小&#xff1a; 图片编辑助手&#xff1a;这是一款功能强大的图像处理软件&#xff0c;其中包含了图像压缩功能。您可以打开需要压缩的图片&#xf…