vue2 el-table新增行内删除行内(两种写法)里面第一个是树组件,第二个是数字组件,第一个数组件只能勾选最后一个节点

第一种

<template>
  <div class="time_table">
    <div style="margin-bottom: 10px">
      <el-button @click="addRowFn">新增</el-button>
    </div>
    <el-form ref="costForm" :model="formData">
      <el-table :data="formData.tableData" style="width: 100%" :value="tableData">
        <el-table-column prop="productId" label="所属产品(集成选非产线)" type="productId">
          <template #header>
            <span style="color: red; margin-right: 4px">*</span>
            <span>所属产品(集成选非产线)</span>
          </template>
          <template slot-scope="scope">
            <div v-if="!selectSure">
              <div style="display: flex; justify-content: space-between">
                <div> {{ scope.row.productId }} </div>
                <div v-if="scope.$index != cellIndexInput" @click="gropeFn(scope, scope.row)">
                  <el-icon class="el-icon-search"></el-icon>
                </div>
              </div>
            </div>
            <div v-if="scope.row.productId == '' || scope.row.productId == null">
              <div class="titelno-style">
                {{ `请填写所属产品` }}
              </div>
            </div>
            <div v-if="scope.$index == cellIndexInput && tableId == scope.row.id" style="display: flex; justify-content: space-between">
              <div class="about">
                <el-select
                  v-model="selectValue"
                  placeholder="请选择"
                  :popper-append-to-body="false"
                  @remove-tag="removetag"
                  @clear="clearall"
                  clearable
                  filterable
                  collapse-tags
                  ref="select"
                  @change="changelabel"
                >
                  <el-input style="width: 260px; margin: 10px" placeholder="输入关键字进行过滤" v-model="filterText"> </el-input>
                  <el-option :value="selectTree" class="setstyle" disabled>
                    <el-tree
                      :filter-node-method="filterNode"
                      :data="list"
                      @node-click="handleNodeClick"
                      :props="defaultProps"
                      ref="tree"
                      node-key="id"
                      default-expand-all
                      highlight-current
                    ></el-tree>
                  </el-option>
                </el-select>
              </div>
            </div>
            <div v-if="scope.$index !== cellIndexInput && selectSure">
              <div style="display: flex; justify-content: space-between">
                <div> {{ scope.row.productId }} </div>
                <div v-if="scope.$index != cellIndexInput" @click="gropeFn(scope, scope.row)"> <el-icon class="el-icon-search"></el-icon> </div>
              </div>
            </div>
          </template>
        </el-table-column>
        <el-table-column prop="productMoney" label="产品金额" type="productMoney">
          <template #header>
            <span style="color: red; margin-right: 4px">*</span>
            <span>产品金额</span>
          </template>
          <template slot-scope="scope">
            <div v-if="!numberSure">
              <div style="display: flex; justify-content: space-between">
                <div> {{ scope.row.productMoney | currencyFormat }} </div>
                <div v-if="scope.$index != cellIndexnumber" @click="gropesFn(scope, scope.row, scope.row.productMoney)">
                  <el-icon class="el-icon-search"></el-icon>
                </div>
              </div>
            </div>
            <div v-if="scope.row.productMoney == '' || scope.row.productMoney == null">
              <div class="titelno-style">
                {{ `请填写所属金额` }}
              </div>
            </div>
            <div v-if="scope.$index == cellIndexnumber && tablelistId == scope.row.id" style="display: flex; justify-content: space-between">
              <inputNumberA
                :values="values"
                :newDates="newDates"
                :rowinputNumber="rowinputNumber"
                @close="closeinputNumberFn"
                @change="changeinputNumberFn"
              ></inputNumberA>
              <!-- <el-form-item :prop="`tableData.${scope.$index}.productMoney`" :rules="[{ required: true, message: '请输入' }]">
                <el-input v-model.trim="scope.row.productMoney" @keyup.native="handleNumberType" style="width: 250px" placeholder="请输入"></el-input>
              </el-form-item> -->
            </div>
            <div style="display: flex; justify-content: space-between" v-if="scope.$index !== cellIndexnumber && numberSure">
              <div>$ {{ scope.row.productMoney | currencyFormat }} </div>
              <div @click="gropesFn(scope, scope.row)">
                <el-icon class="el-icon-search"></el-icon>
              </div>
            </div>
          </template>
        </el-table-column>

        <el-table-column prop="answer" label="操作">
          <template slot-scope="scope">
            <el-button @click="delOptionFn(scope.$index, tableData)">删除</el-button>
          </template>
        </el-table-column>
      </el-table>
    </el-form>
  </div>
</template>

<script>
import inputNumberA from './inputNumber.vue'

function filterTreeData(treeData) {
  return treeData.filter((item) => {
    if (isNotEmpty(item.children)) {
      item.disabled = true
      item.children = filterTreeData(item.children)
    }
    return item
  })
}
function isNotEmpty(arr) {
  return arr && Array.isArray(arr) && arr.length > 0
}
function addToTreeFn(treeData, type1) {
  treeData.forEach((node) => {
    if (node.children && node.children.length > 0) {
      addToTreeFn(node.children, type1)
    } else {
      node.sos = type1
    }
  })
}

export default {
  name: 'timeTable',
  props: {
    value: {
      type: Array,
      default: () => [{}],
    },
  },

  components: {
    inputNumberA,
  },
  data() {
    return {
      dialogVisible: true,
      selectValue: '',
      selectTree: [],
      expandedList: [],
      filterText: '', //input搜索
      rowinputNumber: {},
      list: [],
      defaultProps: {
        children: 'children',
        label: 'label',
      },
      nameValue: '',
      defaultValue: [], //tree唯一的id
      values: '',
      newDates: {},
      formData: {
        // tableData: [...this.value],
        tableData: [],
      },
      tableId: '',
      cellIndexInput: null,
      cellIndexnumber: null,
      prodectmark: null,

      options: [], //节点下拉框数据

      selectSure: false,
      numberSure: false,
      tablelistId: '',
      //验证规则
      rules: {
        // productId: [
        //   {
        //     required: true,
        //     message: '请输入姓名',
        //     trigger: ['blur', 'change'],
        //   },
        // ],
        sex: [
          {
            required: true,
            message: '请选择性别',
            trigger: ['blur', 'change'],
          },
        ],
      },
      tableData: [],
    }
  },
  watch: {
    tableData: {
      handler(newval) {
        this.$emit('input', newval)
      },
      deep: true,
    },
    selectValue(newValue) {
      this.changelabel(newValue)
    },
    // 搜索
    filterText(val) {
      this.$refs.tree.filter(val)
    },
    value: {
      handler(newval) {
        this.handleFn(newval)
        console.log(newval, 'newval_____')
      },
      deep: true,
    },
  },
  created() {
    console.log(this.value, 'yyiyyyyyyyyyyyyy')
    // this.fetchEntryTimeDic()
    // this.listFn()
    this.treeFn()
  },
  methods: {
    handleFn(val) {
      // this.formData.tableData = val
      // const v = val
      // const vo = v.map((item) => {
      //   return { productId: item.productName, productMoney: item.productMoney, productName: item.productId }
      // })

      this.formData.tableData = val
    },
    changelabel(val) {
      console.log('changelabel----', val)
    },
    // 下拉框移除
    removetag() {
      this.$refs.tree.setCheckedKeys([])
    },
    // 可清空的单选模式下用户点击清空按钮时触发
    clearall() {
      this.selectTree = []
      this.$nextTick(() => {
        this.$refs.tree.setCheckedNodes([])
      })
    },
    handleNodeClick(data, node) {
      let arr = []
      if (data.sos === '1') {
        arr.push(data)
        this.selectTree = arr[0]
        this.selectValue = this.selectTree.label
        this.$nextTick(() => {
          if (this.selectValue !== '') {
            this.$emit('treechagelist', this.selectTree, this.row1)
            this.cellIndexInput = null
          }
        })
      }
    },
    // 模糊查询(搜索过滤),实质为筛选出树形控件中符合输入条件的选项,过滤掉其他选项
    filterNode(value, data) {
      console.log(value, 'kkkkkkkkkkkkkkkk')
      if (!value) return true
      let filterRes = data.label.indexOf(value) !== -1
      return filterRes
    },
    treeFn() {
      // 接口
      treeAPI().then((res) => {
        this.list = res
        this.selectValue = ''
        addToTreeFn(this.list, '1')
        filterTreeData(this.list)
      })
    },

    gropeFn(v, row) {
      console.log(row, v, 'gropeFn-----------', row.productId)
      this.selectValue = row.productId
      console.log(this.selectValue, ' this.selectValue ')
      this.selectSure = true
      this.tableId = row.id
      this.cellIndexInput = v.$index
      this.rows = row
      this.row1 = v
      console.log(row.id, ' row.id')
    },
    gropesFn(v, row, i) {
      console.log(v, row, 'gropesFn', i)
      this.numberSure = true
      this.tablelistId = row.id
      this.cellIndexnumber = v.$index
      this.values = i
      this.newDates = v
    },
    //表格的单元格单机  --->  将每行的isEdit改成true
    rowClickFn(row, column, event) {
      this.$set(row, 'isEdit', true)
    },
    // 新增
    addRowFn() {
      this.formData.tableData.unshift({
        productMoney: '',
        productId: '',
        productName: '',
      })
      this.selectValue = ''
    },
    // 下面的数据保存
    addFn(id, tableData) {
      tableData.orderNum = Number(tableData.orderNum)
      // 存起来数据
      localStorage.setItem('tableData', JSON.stringify(tableData)),
        // 取出来
        localStorage.getItem('tableData')
      this.tableData = JSON.parse(localStorage.getItem('tableData'))
      this.tableData.forEach((item) => {
        item.orderNum = Number(item.orderNum)
      })
      if (!tableData[id].productMoney) {
        return this.$message.error('请您填写描述信息哦~')
      }
    },

    delOptionFn(index) {
      this.formData.tableData.splice(index, 1)
    },
    async upOption(row) {
      console.log(row)
    },

    closeinputNumberFn() {
      this.handleChange()
    },
    handleChange() {
      this.inputNumberSure = false
      this.cellIndexNumber = null
    },
    changeinputNumberFn(val, v, row) {
      this.$emit('inputnumberchagelist', Number(val), row)
      this.cellIndexnumber = null
    },
    handleClose() {
      this.dialogVisible = false
    },
  },
}
</script>

<style lang="scss" scoped>
/* ::v-deep.el-table--fit {
  border-right: 0;
  border-bottom: 0;
  margin-left: -55px;
} */
.titelno-style {
  color: red;
  font-size: 8px;
}
.setstyle {
  min-height: 200px;
  padding: 0 !important;
  margin: 0;
  overflow: auto;
  cursor: default !important;
}
</style>

inputNumber.vue文件

<template>
  <div class="cell-input-number">
    <input type="number" class="cell-input-inner" ref="inputEl" size="mini" v-model.trim="newValue" @blur="handleBlur" :min="mins" :max="maxs" />
  </div>
</template>

<script>
export default {
  props: {
    values: {
      type: [String, Number],
      required: false,
      default: '',
    },
    rowinputNumber: {
      type: Object,
      default: () => {},
    },
    newDates: {
      type: Object,
      default: () => {},
    },
  },
  data() {
    return {
      newValue: '',
      currentHeight: this.height,
      mins: 0,
      maxs: 0,
    }
  },
  created() {
    console.log(this.rowinputNumber, 'rowinputNumberrowinputNumber')
  },
  mounted() {
    this.newValue = this.values
    // 用户双击后,让其处于获取焦点的状态
    this.$refs.inputEl.focus()
  },
  methods: {
    formatInput(val) {
      console.log(val, 'hhhhhhhhhhhhhhhhhhhh')
    },
    parseInput() {},
    checknum() {},
    numberChangeFn(event) {
      console.log(event, 'yyyyyyy')
    },
    handleInput(event) {
      console.log(event, 'event')
      const { values, selectionStart, selectionEnd } = event.target

      // 只保留数字和小数点
      let pureValue = values.replace(/[^\d.]/g, '')

      // 如果小数点超过一个,只保留第一个
      const idx = pureValue.indexOf('.')
      if (idx !== -1 && pureValue.indexOf('.', idx + 1) !== -1) {
        pureValue = pureValue.slice(0, idx + 1) + pureValue.slice(idx + 1).replace(/\./g, '')
      }

      // 如果小数点在开头,前面加 0
      const isBeginningWithDot = pureValue[0] === '.'
      let newValue = isBeginningWithDot ? `0${pureValue}` : pureValue

      // 根据光标位置修改输入值
      const num = Number(newValue)
      if (num > 0 && selectionStart !== selectionEnd) {
        const start = Math.max(selectionStart, newValue.indexOf(num))
        const end = Math.min(selectionEnd, newValue.indexOf(num) + String(num).length)
        newValue = newValue.slice(0, start) + num + newValue.slice(end, newValue.length)
      }

      // 更新输入框中的值和组件中的值
      event.target.values = newValue

      this.newValue = newValue
    },
    handleBlur() {
      if (this.newValue !== this.values) {
        if (this.newValue === '') {
          this.newValue = 0
        }
        this.$emit('change', this.newValue, this.rowinputNumber, this.newDates)
      }
      this.$emit('close')
    },
  },
}
</script>

<style lang="scss">
.cell-input-number {
  width: 100%;
  height: 100%;
  background-color: #fff;
  font-size: inherit;
  box-shadow: 0 0 24px #0000002e;
  .cell-input-inner {
    margin: 0;
    padding: 2px 8px;
    font-size: inherit;
    border: none;
    outline: none;
    width: 100%;
    height: 100%;
    background-color: transparent;
    line-height: 23px;
    resize: none;
    overflow: hidden;
    white-space: pre-wrap;
    word-break: break-all;
    font-family: inherit;
    box-sizing: border-box;
  }
}
</style>

父页面

拿到数据传递给子去,然后进项本地储存 ,监听

    inputnumberchagelistFn(i, row) {
      this.$set(this.value[row.$index], 'productMoney', i)
      localStorage.setItem('mutate-1', JSON.stringify(this.value))
    },
    treechagelistFn(i, row) {
      this.$set(this.value[row.$index], 'productId', i.label)
      localStorage.setItem('mutate-1', JSON.stringify(this.value))
      this.$set(this.value[row.$index], 'id', i.id)
    },

第二种写法

<template>
  <div class="time_table">
    <el-card style="margin-bottom: 20px">
      <div slot="header" class="clearfix">
        <el-button type="text" @click="newlyAddedFn">新增</el-button>
      </div>
      <el-table border :data="tableData" style="width: 100%" :value="tableData">
        <el-table-column label="序号" width="100px" align="center">
          <template slot-scope="scope">
            {{ scope.$index + 1 }}
          </template>
        </el-table-column>
        <el-table-column prop="productId" label="xxxxx">
          <template slot-scope="scope">
            <el-select
              :filter-method="filterMethod"
              filterable
              :ref="'productId' + scope.$index"
              v-model="tableData[scope.$index]['productId']"
              placeholder="请选择文档类别"
              clearable
            >
              <el-option :value="tableData[scope.$index]['productId']" style="height: auto">
                <el-tree
                  :filter-node-method="filterNode"
                  :ref="'categoryNameTree' + scope.$index"
                  :data="data"
                  node-key="id"
                  :props="defaultProps"
                  @node-click="getTypeList(scope.$index, scope)"
                  :expand-on-click-node="false"
                  default-expand-all
                >
                  <span slot-scope="{ node }">{{ node.label }}</span>
                </el-tree>
              </el-option>
            </el-select>
            <div style="color: red; font-size: 12px" v-if="JSON.stringify(scope.row) == '{}' || scope.row.productId == ''"> 请选择所属产品(集成选非产线) </div>
          </template>
        </el-table-column>

        <el-table-column prop="productMoney" label="产品金额" :sortable="true">
          <template slot-scope="scope">
            <el-input type="number" v-model="scope.row.productMoney" placeholder="请输入数字"> </el-input>
            <div
              style="color: red; font-size: 12px"
              v-if="JSON.stringify(scope.row) == '{}' || scope.row.productMoney == null || scope.row.productMoney == 0 || scope.row.productMoney == ''"
            >
              请输入产品金额
            </div>
          </template>
        </el-table-column>
        <el-table-column prop="answer" label="操作" width="100px">
          <template slot-scope="{ row }">
            <el-button type="text" @click="delOption(row, tableData)">
              <span style="color: red">删除</span>
            </el-button>
          </template>
        </el-table-column>
      </el-table>
      <div class="money-style">
        <div class="amount-to-style">合计:</div>
        <div class="total-quotation-style">
          {{ preSignMoney | currencyFormat }}
        </div>
      </div>
    </el-card>
  </div>
</template>

<script>


export default {
  name: 'induction',
  props: {
    value: {
      type: Array,
      default: () => [],
    },
  },
  data() {
    return {
      preSignMoney: '',
      categoryId: null,
      tableData: [{}],
      options: [],
      data: [],
      dialogVisible: false,
      defaultProps: {
        children: 'children',
        label: 'label',
      },
    }
  },
  created() {
    this.getListFn()
    this.tableData = this.value
  },
  watch: {
    tableData: {
      handler(newval) {
        this.$emit('input', newval)
        this.countFn(newval)
      },
      deep: true,
    },
    value(val) {
      this.tableData = val
    },
  },

  methods: {
    countFn(data) {
      const total = data.reduce((accumulator, currentItem) => {
        return Number(accumulator) + Number(currentItem.productMoney)
      }, 0)
      this.preSignMoney = total
    },
    // 新增
    newlyAddedFn() {
      this.tableData.unshift({ productMoney: '', productId: '', productName: '' })
    },

    // 删除
    delOption(index, data) {
      data.splice(index, 1)
    },
    getListFn() {
      treeAPI().then((res) => {
        this.data = res
      })
    },
    filterNode(value, data) {
      if (!value) return true
      return data.label.indexOf(value) !== -1
    },
    filterMethod(value) {
      this.$refs.tree.filter(value)
    },

    clearValue() {
      this.$refs.tree.setCurrentKey(null)
    },
    getTypeList(index, row) {
      console.log(index, 'ccvcv', row)
      // .getCurrentKey()获取到当前要选择节点的key值
      // 使用此方法必须设置 node-key 属性,若没有节点被选中则返回 null
      const nodeId = this.$refs['categoryNameTree' + index].getCurrentKey()
      // .getNode(nodeId) 根据 data 或者 key 拿到 Tree 组件中的 node
      const node = this.$refs['categoryNameTree' + index].getNode(nodeId)
      if (node.childNodes.length === 0) {
        // 根据index给当前元素的categoryName参数赋值
        this.$set(this.tableData[index], 'productId', node.label)
        this.$set(this.tableData[index], 'label', node.data.id)

        // 此时页面上已经可以动态选择
        // 这一步是通过判断当前元素的v-model是否有值来控制el-option是否隐藏
        if (this.tableData[index].productId) {
          // .blur()用来隐藏当前展开的下拉选择框
          this.$refs['productId' + index].blur()
        }
      } else {
        this.$message({
          message: '请勾选子级',
          type: 'warring',
        })
      }
    },
  },
}
</script>
<style lang="scss" scoped>
.money-style {
  height: 46px;
  font-size: 16px;
  // margin-top: 20px;
  border-right: 1px solid #d9dbe0;
  border-left: 1px solid #d9dbe0;
  border-bottom: 1px solid #d9dbe0;
  line-height: 23px;

  display: -webkit-box;
  .amount-to-style {
    width: 50%;
    text-align: center;
    line-height: 44px;
    border-right: 1px solid #d9dbe0;
  }
  .total-quotation-style {
    text-align: center;

    line-height: 44px;

    width: 50%;
  }
}
</style>

父页面

   inputChange(val) {
      this.tablesProps = val
    },

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

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

相关文章

普渡机器人CEO预测2024年服务机器人市场将扩大

原创 | 文 BFT机器人 根据普渡科技有限公司的报告&#xff0c;商用服务机器人在东亚地区的应用比其他地方更为广泛。然而&#xff0c;预计到2024年&#xff0c;全球其他地区也将迎头赶上。这家总部位于中国深圳的公司自豪地宣称&#xff0c;它已经成为中国最大的此类机器人出口…

基于QPSO-LSTM的短期风电负荷MATLAB预测程序

微❤关注“电气仔推送”获得资料&#xff08;专享优惠&#xff09; 参考文献 基于QPSO-LSTM的短期风电负荷预测模型——谭才兴&#xff08;完全复现&#xff09; 程序简介 传统的LSTM神经网络超参数和拓扑结构通常是基于经验和试验确定&#xff0c;但这种方法容易受到人为因…

uniapp中配置开发环境和生产环境

uniapp在开发的时候&#xff0c;可以配置多种环境&#xff0c;用于自动切换IP地址&#xff0c;用HBuilder X直接运行的就是开发环境&#xff0c;用HBuilder X发布出来的&#xff0c;就是生产环境。 1.使用HBuilder X创建原生的uniapp程序 选择vue3 2.什么都不改&#xff0c;就…

【SAR成像】基于RD、CS和ωk算法的合成孔径雷达成像算法原理与实现

基于RD、CS和ωk算法的合成孔径雷达成像算法实现 前言SAR基本概念雷达获取数据的几何关系低斜视角下的回波信号模型 RADARSAT-1主要参数数据预处理数据读取与再封装数据补零 成像算法坐标轴的产生RD算法距离压缩距离徙动矫正方位压缩 CS算法第一次相位相乘 变标后的信号第二次相…

由亚马逊云科技 Graviton4 驱动的全新内存优化型实例 Amazon EC2 实例(R8g),现已开放预览

下一代 Amazon Elastic Compute CloudAmazon EC2) 实例的预览版现已公开 提供。全新的 R8g 实例 搭载新式 Graviton4 处理器&#xff0c;其性价比远超任何现有的内存优化实例。对于要求较高的内存密集型工作负载&#xff0c;R8g 实例是不二之选&#xff1a;大数据分析、高性能数…

热数据存储在HDFS,冷备数据存储于对象存储中

1.场景分析 生产环境均为腾讯云服务器&#xff0c;日志数据计划存储于HDFS中&#xff0c;由于日志数据较大&#xff08;压缩后1T/天&#xff09;&#xff0c;不断扩充云盘成本消耗大。鉴于对象存储的存储成本较为低廉&#xff0c;但是日常频繁使用会产生流量费用。 鉴于此&…

ES6中新增Array.of()函数的用法详解

new Array()方法 ES6为Array增加了of函数用一种明确的含义将一个或多个值转换成数组。因为用new Array()构造数组的时候&#xff0c;是有二意性的。 构造时&#xff0c;传一个参数&#xff0c;实际上是指定数组的长度&#xff0c;表示生成多大的数组。 构造时&#xff0c;传…

(源码版)2024美国大学生数学建模E题财产保险的可持续模型详解思路+具体代码季节性时序预测SARIMA天气预测建模

本篇文章是: 2024美国大学生数学建模E题财产保险的可持续模型详解思路+具体代码季节性时序预测SARIMA天气预测建模的源码版本,包含具体建模代码到生成模型步骤。那么废话不多说直接开始展示建模过程建模: 数据预处理 之前我给大家提供的一年的风暴数据是远远不够的,要做时…

前端excel带样式导出 exceljs 插件的使用

本来用的xlsx和xlsx-style两个插件&#xff0c;过程一步一个坑&#xff0c;到完全能用要消灭好多bug。这时发现了exceljs&#xff0c;真香&#x1f600; 案例 <!DOCTYPE html> <html><head><meta charset"utf-8" /><meta name"view…

iOS图像处理----探索图片解压缩到渲染的全过程以及屏幕卡顿

一&#xff1a;图像成像过程 ①、将需要显示的图像&#xff0c;由CPU和GPU通过总线连接起来&#xff0c;在CPU中输出的位图经总线在合适的时机上传给GPU &#xff0c;GPU拿到位图做相应位图的图层渲染、纹理合成。 ②、将渲染后的结果&#xff0c;存储到帧缓存区&#xff0c;帧…

Linux 驱动开发基础知识——设备树的语法驱动开发基础知识(九)

个人名片&#xff1a; &#x1f981;作者简介&#xff1a;学生 &#x1f42f;个人主页&#xff1a;妄北y &#x1f427;个人QQ&#xff1a;2061314755 &#x1f43b;个人邮箱&#xff1a;2061314755qq.com &#x1f989;个人WeChat&#xff1a;Vir2021GKBS &#x1f43c;本文由…

Docker进阶学习笔记-持续更新中

容器数据卷 什么是容器数据卷 docker的理念回顾 将应用和环境打包成一个镜像! 数据﹖如果数据都在容器中,那么我们容器删除,数据就会丢失!需求︰数据可以持久化MySQL,容器删了,删库跑路!需求:MySQL数据可以存储在本地! 容器之间可以有一个数据共享的技术!Docker容器中产生…

阅读欣赏推荐之(一)——纪录片《数学的故事》

寒假是孩子最好的“增值期”&#xff0c;有很多家长选择让孩子“泡在”辅导班&#xff0c;想让孩子弯道超车&#xff0c;但效果往往是不尽人意的。其实&#xff0c;寒假是孩子提高素质、开阔眼界、增加兴趣的黄金时期&#xff0c;特别是学数学有困难的孩子&#xff0c;可以利用…

“量子+材料”!光量子公司PsiQuantum与日本两大巨头强强合作

内容来源&#xff1a;量子前哨&#xff08;ID&#xff1a;Qforepost&#xff09; 编辑丨慕一 编译/排版丨卉可 琳梦 深度好文&#xff1a;1200字丨10分钟阅读 近日&#xff0c;光量子计算公司PsiQuantum和三菱日联金融集团宣布&#xff0c;双方与三菱化学集团达成项目合作—…

Linux文件编译

目录 一、GCC编译 1.直接编译 2.分步编译 预处理&#xff1a; 编译&#xff1a; 汇编&#xff1a; 链接&#xff1a; 3.多文件编译 4.G 二、Make 1.概述 2.使用步骤 3.makefile创建规则 3.1一个基本规则 3.2两个常用函数 4.示例文件 三、GDB 示例&#xff1a;…

精雕细琢的文档体验:Spring Boot 与 Knife4j 完美交汇

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 精雕细琢的文档体验&#xff1a;Spring Boot 与 Knife4j 完美交汇 前言Knife4j 与 Swagger 的区别1. 特性与优劣势对比&#xff1a;Knife4j&#xff1a;Swagger&#xff1a; 2. 选择 Knife4j 的理由&a…

【Linux】静态库和动态库

动静态库 一、静态库1. 静态库概念2. 制作静态库&#xff08;1&#xff09;朴素方法 --- 不打包&#xff08;2&#xff09;对静态库打包 3. 使用静态库&#xff08;1&#xff09;朴素方法 --- 直接使用&#xff08;2&#xff09;使用打包好的静态库 二、动态库1. 动态库概念2. …

读论文:DiffBIR: Towards Blind Image Restoration with Generative Diffusion Prior

DiffBIR 发表于2023年的ICCV&#xff0c;是一种基于生成扩散先验的盲图像恢复模型。它通过两个阶段的处理来去除图像的退化&#xff0c;并细化图像的细节。DiffBIR 的优势在于提供高质量的图像恢复结果&#xff0c;并且具有灵活的参数设置&#xff0c;可以在保真度和质量之间进…

Allegro如何在关闭飞线模式下查看网络连接并显示引脚号

Allegro如何在关闭飞线模式下查看网络连接并显示引脚号 在用Allego进行PCB设计过程中,有时候在关闭全部飞线的情况下,但想查看网络的连接位置。那如何快速查看网络连接,并显示器件的引脚号呢? 操作效果如下图: 具体操作方法如下: 首先选择菜单Logic 选择Net_Schedule(网…

【51单片机】直流电机实验和步进电机实验

目录 直流电机实验直流电机介绍ULN2003 芯片介绍硬件设计软件设计实验现象 步进电机实验步进电机简介步进电机的工作原理步进电机极性区分双极性步进电机驱动原理单极性步进电机驱动原理细分驱动原理 28BYJ-48 步进电机简介软件设计 橙色 直流电机实验 在未学习 PWM 之前&…