首页 > 其他分享 >antdesign vue通用表单生成页面

antdesign vue通用表单生成页面

时间:2023-09-15 17:10:08浏览次数:43  
标签:el vue const res ids else antdesign message 表单

效果图效果图

由于涉及企业敏感信息,信息进行了打码,还请多多包涵。。。

点击左侧菜单树,右侧加载不同table,并且绑定列名不同(说明:前两列企业名称和城市名称固定不变)

antdesign vue通用表单生成页面_ico

技术思路

左侧菜单为标识,控制表单页面的布局和模块显示,字段显示隐藏,可根据下面2附图加深理解,由于信息敏感问题,暂时不提供表结构和数据,如有需要,请邮件652769324@qq.com联系博主

antdesign vue通用表单生成页面_html_02

antdesign vue通用表单生成页面_html_03

commonForm.vue

vue代码

<template>
  <div class="bgwhite" ref="bgwhite">
    <div class="headerText"><a-icon type="unordered-list"></a-icon> {{ directoryName }}</div>
    <a-divider />
    <div class="top">
      <div class="search_item" v-if="postParams.isExistsenp === 1">
        <label class="searchLable">城市名称:</label>
        <a-tree-select
          style="width: 183px"
          v-model="searchParams.regionCode"
          :replace-fields="parentReplaceFields"
          :tree-data="treeData"
          :dropdown-style="{ maxHeight: '800px', overflow: 'auto' }"
          placeholder="请选择城市"
        >
        </a-tree-select>
      </div>
      <div class="search_item" v-if="postParams.isExistsenp === 1">
        <label class="searchLable">企业名称:</label>
        <a-input type="text" v-model="searchParams.enpName" placeholder="请输入企业名称" />
      </div>
      <div class="search_item" v-for="(field, index) in dynamicSearchForm" :key="index">
        <label class="searchLable">{{ field.itemDesc }}: </label>
        <template v-if="field.htmlType === 'input'">
          <a-date-picker
            v-if="field.itemDatatype === 'date-year'"
            mode="year"
            format="YYYY"
            allowClear
            v-model="searchParams[`${field.uriItem}Date`]"
            :placeholder="`请选择${field.itemDesc}`"
            style="width: 100%"
            :open="yearPicker"
            :disabledDate="disabledYearDate"
            @openChange="openYearChange"
            @panelChange="(date) => panelYearChange(date, field.uriItem)"
          />
          <a-month-picker
            v-else-if="field.itemDatatype === 'date-month'"
            mode="month"
            format="YYYY-MM"
            allowClear
            v-model="searchParams[`${field.uriItem}Date`]"
            :placeholder="`请选择${field.itemDesc}`"
            style="width: 100%"
            @change="(_, dateStr) => handleDateChange(dateStr, field.uriItem)"
          />
          <a-date-picker
            v-else-if="field.itemDatatype === 'date-day'"
            mode="date"
            format="YYYY-MM-DD"
            allowClear
            v-model="searchParams[`${field.uriItem}Date`]"
            :placeholder="`请选择${field.itemDesc}`"
            style="width: 100%"
            @change="(_, dateStr) => handleDateChange(dateStr, field.uriItem)"
          />
          <a-date-picker
            v-else-if="field.itemDatatype === 'date-hour'"
            format="YYYY-MM-DD HH"
            allowClear
            mode="time"
            v-model="searchParams[`${field.uriItem}Date`]"
            :placeholder="`请选择${field.itemDesc}`"
            style="width: 100%"
            @change="(_, dateStr) => handleDateChange(dateStr, field.uriItem)"
          />
          <a-date-picker
            v-else-if="field.itemDatatype === 'date-minute'"
            mode="time"
            format="YYYY-MM-DD HH:mm"
            allowClear
            v-model="searchParams[`${field.uriItem}Date`]"
            :placeholder="`请选择${field.itemDesc}`"
            style="width: 100%"
            @change="(_, dateStr) => handleDateChange(dateStr, field.uriItem)"
          />
          <a-date-picker
            v-else-if="field.itemDatatype === 'date-second'"
            mode="time"
            format="YYYY-MM-DD HH:mm:ss"
            allowClear
            v-model="searchParams[`${field.uriItem}Date`]"
            :placeholder="`请选择${field.itemDesc}`"
            style="width: 100%"
            @change="(_, dateStr) => handleDateChange(dateStr, field.uriItem)"
          />
          <a-input-number
            v-model="searchParams[field.uriItem]"
            :placeholder="`请选择${field.itemDesc}`"
            v-else-if="field.itemDatatype === 'number'"
          ></a-input-number>
          <a-input v-model="searchParams[field.uriItem]" :placeholder="`请选择${field.itemDesc}`" v-else></a-input>
        </template>

        <template v-else-if="field.htmlType === 'textarea'">
          <a-textarea v-model="searchParams[field.uriItem]" :placeholder="`请输入${field.itemDesc}`" />
        </template>
        <template v-else-if="field.htmlType === 'select'">
          <a-select
            v-model="searchParams[field.uriItem]"
            :placeholder="`请选择${field.itemDesc}`"
            style="width: 183px"
            :dropdown-style="{ maxHeight: '240px', overflow: 'auto' }"
          >
            <a-select-option v-for="(item, zindex) in field.options" :key="zindex" :value="item.value">{{
              item.name
            }}</a-select-option>
          </a-select>
        </template>
        <template v-else-if="field.htmlType === 'radio'">
          <a-radio-group v-model="searchParams[field.uriItem]">
            <a-radio v-for="(item, rindex) in ZMD_YN" :key="rindex" :value="item.value">
              {{ item.name }}
            </a-radio>
          </a-radio-group>
        </template>
      </div>
      <div class="search_item">
        <a-button type="primary" v-action:query @click="handleSearch">查询</a-button>
        <a-button type="primary" v-action:query @click="handleExport">导出</a-button>
      </div>
    </div>
    <div class="mid">
      <div class="mid_header">
        <div class="mid_header_item">
          <a-button type="primary" v-action:add @click="handleAdd">新增</a-button>
          <a-button type="primary" v-action:edit @click="handleEdit">编辑</a-button>
          <a-button type="primary"
                    v-action:relation
                    @click="handleRelation"
                    v-if="postParams.isExistsenp === 1"
          >智能关联企业</a-button
          >
          <a-button type="primary" v-action:import @click="handleImport">批量入库</a-button>
          <a-button type="primary" v-action:back @click="handleBack">批量置回</a-button>
          <a-button type="primary" v-action:del @click="handleDel">批量删除</a-button>
        </div>
      </div>
      <a-table
        id="apptable"
        row-key="ids"
        :columns="columns"
        :data-source="data"
        :bordered="true"
        :pagination="pagination"
        :row-selection="rowSelection"
        :loading="isLoading"
        :scroll="{ x: 1100, y: tableH }"
        @change="TableChange"
      >
        <span slot="serial" slot-scope="text, record, index">
          {{ index + 1 }}
        </span>
        <span slot="enpName" slot-scope="text, record">
          <a @click="OpenDetailInfo(record.ids)">{{ text }} </a>
        </span>
        <span slot="operation" slot-scope="text, record">
          <a @click="openModal(record.ids, record.enpName)"> 选择 </a><span>{{ record.relationEnpName }}</span>
        </span>
      </a-table>
      <a-modal
        :width="1080"
        centered
        v-drag-modal
        v-model="visible"
        :title="modalTitle"
        :destroyOnClose="true"
        @ok="handleOk"
        :footer="showFooter === true ? null : undefined"
      >
        <infoModal
          ref="childModal"
          :modalTitle="modalTitle"
          :form="form"
          :contentId="id"
          :postParams="postParams"
          :infoId="keyWord"
          :selectedId="selectedId"
        />
      </a-modal>
      <a-modal
        width="70%"
        centered
        v-drag-modal
        v-model="tableVisible"
        :title="tableModalTitle"
        :destroyOnClose="true"
        @ok="handletableOk"
        :footer="showFooter === true ? null : undefined"
      >
        <tableForm
          ref="childTableModal"
          :tableModalTitle="tableModalTitle"
          :form="form"
          :contentId="id"
          :postParams="postParams"
          :infoId="keyWord"
          :selectedId="selectedId"
        />
      </a-modal>
      <a-modal
        :width="900"
        centered
        v-drag-modal
        v-model="relationVisible"
        title="智能关联企业"
        :destroyOnClose="true"
        @ok="handleRelationOk"
      >
        <RelationModal ref="childRelationModal" :infoId="keyWord" />
      </a-modal>
      <a-modal
        :width="900"
        centered
        v-drag-modal
        v-model="relationInfoVisible"
        title="选择关联企业"
        :destroyOnClose="true"
      ><RelationInfoModal
         ref="childRelationInfoModal"
         :infoId="keyWord"
         :selectedId="selectedId"
         :selectedEnpName="selectedEnpName"
       />
        <template #footer>
          <a-button @click="handleCancel">取消</a-button>
          <a-button type="primary" @click="handleRelationInfoOk(1)">确定关联</a-button>
          <a-button type="primary" @click="handleRelationInfoOk(0)">取消关联</a-button>
        </template>
      </a-modal>
    </div>
  </div>
</template>

JS部分

<script>
import {
  selectResourceIdentifier,
  selectResourceField,
  queryCommonDataById,
  deleteData,
  queryCommonData,
  addData,
  updateData,
  batchEnterCommonData,
  batchPutBackCommonData,
  saveRelateEnterprise,
  getRegionTreeData,
  exportData,
  deleteRelateEnterprise,
  batchSave,
  batchUpdate
} from '@/dataCenter/commonConfig/infomationManage-api'
import moment from 'moment'
import { exportTableHead } from '@/assets/js/common'
const columns = [
  {
    title: '序号',
    align: 'center',
    scopedSlots: { customRender: 'serial' },
    width: 50,
    checked: true,
    fixed: 'left'
  }
]
const cols = [
  {
    title: '企业名称',
    align: 'left',
    dataIndex: 'enpName',
    scopedSlots: { customRender: 'enpName' },
    width: 220,
    checked: true,
    fixed: 'left'
  },
  {
    title: '城市名称',
    align: 'center',
    dataIndex: 'regionName',
    width: 150,
    checked: true,
    fixed: 'left'
  }
]
const statusMap = {
  0: {
    color: 'red',
    text: '否'
  },
  1: {
    color: 'green',
    text: '是'
  }
}
export default {
  components: {
    infoModal: () => import('@/dataCenter/commonConfig/infomationManageModal'),
    RelationModal: () => import('@/dataCenter/commonConfig/relationEnpModal'),
    RelationInfoModal: () => import('@/dataCenter/commonConfig/relationEnpInfoModal'),
    tableForm: () => import('@/dataCenter/commonConfig/tableForm')
  },
  props: {
    keyWord: {
      type: String,
      default: null
    },
    directoryName: {
      type: String,
      default: null
    }
  },
  data () {
    return {
      columns,
      parentReplaceFields: {
        title: 'regionName',
        value: 'regionCode'
      },
      searchParams: {
        regionCode: this.$store.getters.getLngAndLat.regionCode,
        enpName: ''
      },
      dynamicSearchForm: [],
      postParams: {
        isExistsenp: 0,
        isExistFile: 0,
        colLayout: ''
      },
      treeData: [],
      modalTitle: '',
      visible: false,
      relationInfoVisible: false,
      relationVisible: false,
      tableModalTitle: '',
      tableVisible: false,
      isLoading: false,
      selectedId: '',
      id: '',
      tablename: '',
      selectedEnpName: '',
      selectedRowsArr: [], // 弹窗选中行
      selectedRowKeys: [],
      pagination: {
        current: 1,
        pageSize: 15,
        total: 0,
        showTotal: (total, range) => `${range[0]}-${range[1]} 共 ${total} 条`
      },
      data: [],
      form: {
        ids: '',
        keyWord: '',
        uniCode: '',
        enpName: '',
        regionCode: this.$store.getters.getLngAndLat.regionCode,
        regionName: this.$store.getters.getLngAndLat.regionName,
        remark: null,
        status: 1,
        oldIds: null
      },
      yearPicker: false,
      showFooter: false,
      tableH: 500,
      hasChild: false
    }
  },
  computed: {
    rowSelection () {
      const { selectedRowKeys } = this
      return {
        columnWidth: 40,
        selectedRowKeys,
        onChange: this.onSelectChange
      }
    }
  },
  filters: {
    statusFilter (type) {
      return statusMap[type].text
    },
    statusColorFilter (type) {
      return statusMap[type].color
    }
  },
  watch: {
    keyWord (a) {
      this.getIdByUriId()
      this.getRegionTreeData()
    }
  },
  mounted () {
    this.getIdByUriId()
    this.getRegionTreeData()
  },
  methods: {
    resize () {
      const bgwhite = this.$refs.bgwhite.clientHeight
      const top = this.$refs.bgwhite.querySelector('.top').clientHeight
      this.tableH = bgwhite - top - 200
    },
    getIdByUriId () {
      this.isLoading = true
      const params = {
        pageNum: this.pagination.current,
        pageSize: this.pagination.pageSize,
        uriId: this.keyWord
      }
      selectResourceIdentifier(params)
        .then((res) => {
          if (res.result.list.length > 0) {
            this.id = res.result.list[0].id
            this.postParams.isExistsenp = res.result.list[0].isExistsenp
            this.postParams.isExistFile = res.result.list[0].isExistsfile
            this.postParams.colLayout = res.result.list[0].colLayout
            this.tablename = res.result.list[0].useTable
            if (res.result.list[0].childcount > 0) {
              this.hasChild = true
            } else { this.hasChild = false }
            this.getQueryConditions(this.id)
            this.getListColumns(this.id)
          }
        })
        .catch((err) => console.log(err))
    },
    getRegionTreeData () {
      getRegionTreeData()
        .then((res) => {
          this.treeData = res.result
        })
        .catch((err) => console.log(err))
    },
    getQueryConditions (id) {
      this.dynamicSearchForm = {}
      this.searchParams = {
        regionCode: this.$store.getters.getLngAndLat.regionCode,
        enpName: ''
      }
      const params = {
        pageNum: 0,
        isQuery: 1,
        uriId: id
      }
      selectResourceField(params)
        .then((res) => {
          this.dynamicSearchForm = res.result.list
          this.dynamicSearchForm.forEach((el, index) => {
            if (el.htmlType === 'select') {
              const selectAttr = []
              var names = el.itemNames.split('|')
              var codes = el.itemCodes.split('|')
              names.forEach((val, index) => {
                selectAttr.push({
                  name: val,
                  value: codes[index]
                })
              })
              el.options = selectAttr
            }
            if (el.itemDatatype.includes('date-')) {
              // this.$set(this.searchParams, el.uriItem, moment().format(this.dealFormat(el.itemDatatype)))
              // this.$set(this.searchParams, `${el.uriItem}Date`, moment())
              this.$set(this.searchParams, el.uriItem, '')
              this.$set(this.searchParams, `${el.uriItem}Date`, null)
            }
          })
          setTimeout(() => {
            this.resize()
          }, 200)
        })
        .catch((err) => console.log(err))
    },
    dealFormat (type) {
      switch (type) {
        case 'date-year':
          return 'YYYY'
        case 'date-month':
          return 'YYYY-MM'
        case 'date-day':
          return 'YYYY-MM-DD'
        case 'date-hour':
          return 'YYYY-MM-DD HH'
        case 'date-minute':
          return 'YYYY-MM-DD HH:mm'
        case 'date-second':
          return 'YYYY-MM-DD HH:mm:ss'
      }
    },
    handleDateChange (dateStr, uriItem) {
      this.$set(this.searchParams, uriItem, dateStr)
    },
    getListColumns (id) {
      this.selectedRowKeys = []
      this.selectedRowsArr = []
      const params = {
        pageNum: this.pagination.current,
        pageSize: this.pagination.pageSize,
        keyWord: this.keyWord,
        ...this.searchParams
      }
      queryCommonData(params).then((res) => {
        if (res.result !== null) {
          this.data = res.result.records
          this.pagination.total = res.result.total
          this.isLoading = false
        }
      })
      selectResourceField({ pageNum: 0, isShow: 1, uriId: id })
        .then((res) => {
          this.columns = [...columns]
          if (this.postParams.isExistsenp === 1) {
            this.columns = this.columns.concat(cols)
          }
          res.result.list.forEach((el) => {
            let textAlign = 'center'
            if (el.textAlign === '2') {
              textAlign = 'right'
            } else if (el.textAlign === '3') {
              textAlign = 'left'
            }
            if (el.itemDesc.includes('是否')) {
              this.columns.push({
                title: el.itemDesc,
                customRender: (i, row) => {
                  return (
                    <a-tag color={row[el.uriItem] === '1' ? 'green' : 'red'}>
                      {row[el.uriItem] === '1' ? '是' : '否'}
                    </a-tag>
                  )
                },
                align: 'center',
                width: 150,
                checked: true
              })
            } else {
              this.columns.push({
                title: el.itemDesc,
                dataIndex: el.uriItem,
                align: textAlign,
                width: el.itemDesc.length > 10 ? 260 : 200,
                ellipsis: true,
                customRender: (text, row) => {
                  return (
                    <a-tooltip placement="topLeft" title={text}>
                      {text}
                    </a-tooltip>
                  )
                },
                checked: true
              })
            }
          })
          if (this.postParams.isExistsenp === 1) {
            this.columns.push({
              title: '关联的企业名称',
              align: 'left',
              scopedSlots: { customRender: 'operation' },
              width: 200,
              checked: true,
              fixed: 'right'
            })
          }
        })
        .catch((err) => console.log(err))
    },
    onSelectChange (selectedRowKeys, selectedRows) {
      this.selectedRowKeys = selectedRowKeys
      this.selectedRowsArr = selectedRows
    },
    // 年
    openYearChange (status) {
      this.yearPicker = status
    },
    panelYearChange (value, uriItem) {
      this.$set(this.searchParams, uriItem, value.format('YYYY'))
      this.$set(this.searchParams, `${uriItem}Date`, value)
      this.yearPicker = !this.yearPicker
    },
    disabledYearDate (current) {
      return current && current > moment().endOf('year')
    },
    // 分页改变
    TableChange (e) {
      this.pagination.current = e.current
      this.getListColumns(this.id)
    },

    // 查询
    handleSearch () {
      this.pagination.current = 1
      this.getListColumns(this.id)
    },
    handletableOk () {
      if (this.tableModalTitle === '新增') {
        this.$refs.childTableModal.$refs.ruleForm.validate((valid) => {
          if (valid) {
            this.form.tenantId = this.$store.getters.getTenantId
            this.form.keyWord = this.keyWord
            this.form.childMap = this.$refs.childTableModal.childMap
            delete this.form.dcreate
            batchSave(this.form).then((res) => {
              if (res.code === 200) {
                this.$message.success('保存成功!')
                this.tableVisible = false
                this.getListColumns(this.id)
              } else {
                this.$message.error(res.msg)
              }
            })
          } else {
            return false
          }
        })
      } else {
        this.$refs.childTableModal.$refs.ruleForm.validate((valid) => {
          if (valid) {
            this.form.tenantId = this.$store.getters.getTenantId
            this.form.childMap = this.$refs.childTableModal.childMap
            this.form.childMap.forEach(item => {
              console.log()
              delete item.dcreate
            })
            delete this.form.dcreate
            batchUpdate(this.form).then((res) => {
              if (res.code === 200) {
                this.$message.success('保存成功!')
                this.tableVisible = false
                this.getListColumns(this.id)
              } else {
                this.$message.error(res.msg)
              }
            })
          } else {
            return false
          }
        })
      }
    },
    // 新增保存
    handleOk () {
      if (this.modalTitle === '新增') {
        this.$refs.childModal.$refs.ruleForm.validate((valid) => {
          if (valid) {
            this.form.tenantId = this.$store.getters.getTenantId
            this.form.keyWord = this.keyWord
            addData(this.form).then((res) => {
              if (res.code === 200) {
                this.$message.success('保存成功!')
                this.visible = false
                this.getListColumns(this.id)
              } else {
                this.$message.error(res.msg)
              }
            })
          } else {
            return false
          }
        })
      } else {
        this.$refs.childModal.$refs.ruleForm.validate((valid) => {
          if (valid) {
            this.form.tenantId = this.$store.getters.getTenantId
            console.log(this.form)
            updateData(this.form).then((res) => {
              if (res.code === 200) {
                this.$message.success('保存成功!')
                this.visible = false
                this.getListColumns(this.id)
              } else {
                this.$message.error(res.msg)
              }
            })
          } else {
            return false
          }
        })
      }
    },
    openModal (ids, enpName) {
      this.relationInfoVisible = true
      this.selectedId = ids
      this.selectedEnpName = enpName
    },
    handleCancel () {
      this.relationInfoVisible = false
    },
    handleRelationOk () {
      const enpRelationList = []
      const childData = this.$refs.childRelationModal.data
      childData.forEach((el) => {
        const params = {
          id: '',
          datatableName: this.tablename,
          datatableId: el.ids,
          marked: this.keyWord
        }
        el.baseInfoList.forEach((element) => {
          params.enpcode = element.enpCode
          params.credit_code = element.creditCode
        })
        enpRelationList.push(params)
      })
      saveRelateEnterprise(enpRelationList).then((res) => {
        if (res.code === 200) {
          this.$message.success('智能关联成功!')
          this.relationVisible = false
        } else {
          this.$message.error(res.msg)
        }
      })
    },
    handleRelationInfoOk (status) {
      const _that = this
      const enpRelationList = []
      if (_that.$refs.childRelationInfoModal.selectedRowsArr.length === 1) {
        this.$confirm({
          title: status === 1 ? '确定要关联吗?' : '确定要取消关联吗?',
          onOk () {
            const childData = _that.$refs.childRelationInfoModal.selectedRowsArr[0]
            const params = {
              id: '',
              datatableName: _that.tablename,
              datatableId: _that.selectedId,
              marked: _that.keyWord,
              enpCode: childData.enpCode,
              creditCode: childData.creditCode
            }
            enpRelationList.push(params)
            if (status === 1) {
              saveRelateEnterprise(enpRelationList).then((res) => {
                if (res.code === 200) {
                  _that.$message.success('关联成功!')
                  _that.getListColumns(_that.id)
                  _that.relationInfoVisible = false
                } else {
                  _that.$message.error(res.msg)
                }
              })
            } else if (status === 0) {
              deleteRelateEnterprise({ ids: _that.selectedId, datatableName: _that.tablename }).then((res) => {
                if (res.code === 200) {
                  _that.$message.success('取消关联成功!')
                  _that.getListColumns(_that.id)
                  _that.relationInfoVisible = false
                } else {
                  _that.$message.error(res.msg)
                }
              })
            }
          }
        })
      } else {
        this.$message.warning('请选择一条记录' + (status === 1 ? '关联' : '取消关联'))
        return false
      }
    },
    // 新增
    handleAdd () {
      this.showFooter = false
      this.form = {
        ids: '',
        keyWord: '',
        uniCode: '',
        enpName: '',
        regionCode: this.$store.getters.getLngAndLat.regionCode,
        regionName: this.$store.getters.getLngAndLat.regionName,
        remark: null,
        status: 1,
        oldIds: null
      }
      if (!this.hasChild) {
        this.modalTitle = '新增'
        this.visible = true
      } else {
        this.tableModalTitle = '新增'
        this.tableVisible = true
      }
    },
    OpenDetailInfo (ids) {
      this.showFooter = true
      if (!this.hasChild) {
        this.modalTitle = '查看'
        this.visible = true
      } else {
        this.tableModalTitle = '查看'
        this.tableVisible = true
      }
      queryCommonDataById(ids, { keyWord: this.keyWord })
        .then((res) => {
          for (const item in res.result) {
            this.$set(this.form, item, res.result[item])
          }
        })
        .catch((err) => console.log(err))
      this.form.ids = ids
      this.selectedId = ids
    },
    // 编辑
    handleEdit () {
      if (this.selectedRowsArr.length === 1) {
        if (!this.hasChild) {
          this.modalTitle = '编辑'
          this.visible = true
        } else {
          this.tableModalTitle = '编辑'
          this.tableVisible = true
        }
        this.selectedId = this.selectedRowsArr[0].ids
        this.form.ids = this.selectedRowsArr[0].ids
        queryCommonDataById(this.selectedRowsArr[0].ids, { keyWord: this.keyWord }).then((res) => {
          for (const item in res.result) {
            this.$set(this.form, item, res.result[item])
          }
          this.showFooter = false
        })
      } else {
        this.$message.warning('请选择一条数据!')
        return false
      }
    },

    // 删除
    handleDel () {
      if (this.selectedRowsArr.length >= 1) {
        const _that = this
        this.$confirm({
          title: '确定要删除吗?',
          onOk () {
            let ids = ''
            _that.selectedRowsArr.forEach((item) => {
              ids += item.ids + ','
            })
            ids = ids.substring(0, ids.length - 1)
            deleteData({ enpDataIds: ids, keyWord: _that.keyWord }).then((res) => {
              if (res.code === 200) {
                _that.$message.success('删除成功!')
                _that.getListColumns(_that.id)
              } else {
                _that.$message.error(res.msg)
              }
            })
          }
        })
      } else {
        this.$message.warning('请至少选择一条数据!')
      }
    },
    handleRelation () {
      this.relationVisible = true
    },
    saveRelateEnterprise () {
      if (this.selectedRowsArr.length >= 1) {
        const _that = this
        this.$confirm({
          title: '确定要关联吗?',
          onOk () {
            const enpRelationList = []
            _that.enpselectedRowsArr.forEach((item) => {
              enpRelationList.push({
                id: item.id,
                datatableName: item.datatableName,
                datatableId: item.datatableId,
                marked: _that.keyWord,
                enpCode: item.enpCode,
                credit_code: item.credit_code
              })
            })
            saveRelateEnterprise({ enpRelationList: enpRelationList }).then((res) => {
              if (res.code === 200) {
                _that.$message.success('关联成功!')
              } else {
                _that.$message.error(res.msg)
              }
            })
          }
        })
      } else {
        this.$message.warning('请至少选择一条数据!')
      }
    },
    handleBack () {
      if (this.selectedRowsArr.length >= 1) {
        const _that = this
        this.$confirm({
          title: '确定要批量置回吗?',
          onOk () {
            let ids = ''
            _that.selectedRowsArr.forEach((item) => {
              ids += item.ids + ','
            })
            ids = ids.substring(0, ids.length - 1)
            batchPutBackCommonData({ enpDataIds: ids, keyWord: _that.keyWord }).then((res) => {
              if (res.code === 200) {
                _that.$message.success('置回成功!')
              } else {
                _that.$message.error(res.msg)
              }
            })
          }
        })
      } else {
        this.$message.warning('请至少选择一条数据!')
      }
    },
    handleExport () {
      let columnNames = exportTableHead('apptable')
      if (this.postParams.isExistsenp === 1) {
        columnNames = [...columnNames[1].slice(2), ...columnNames[0].slice(4, columnNames[0].length - 1)]
      } else if (this.postParams.isExistsenp === 0) {
        columnNames = columnNames[0].slice(2)
      }
      console.log(columnNames)
      exportData({
        keyWord: this.keyWord,
        columnCodes: columnNames.map((el) => el.value).join(','),
        columnNames: columnNames.map((el) => el.name).join(',')
      })
        .then((response) => {
          if (response) {
            const dateStr = moment(new Date()).format('YYYYMMDDHHmmss')
            const aLink = document.createElement('a')
            const blob = new Blob([response], { type: 'application/vnd.ms-excel' })
            aLink.href = window.URL.createObjectURL(blob)
            aLink.setAttribute('download', `资源信息管理_${dateStr}.xlsx`)
            aLink.click()
            window.URL.revokeObjectURL(blob)
          } else {
            this.$message.error('导出失败!')
          }
        })
        .catch((error) => {
          console.log(error)
          this.$message.error('导出失败!')
        })
    },
    handleImport () {
      if (this.selectedRowsArr.length >= 1) {
        const _that = this
        this.$confirm({
          title: '确定要批量录入吗?',
          onOk () {
            let ids = ''
            _that.selectedRowsArr.forEach((item) => {
              ids += item.ids + ','
            })
            ids = ids.substring(0, ids.length - 1)
            batchEnterCommonData({ enpDataIds: ids, keyWord: _that.keyWord }).then((res) => {
              if (res.code === 200) {
                _that.$message.success('录入成功!')
              } else {
                _that.$message.error(res.msg)
              }
            })
          }
        })
      } else {
        this.$message.warning('请至少选择一条数据!')
      }
    }
  }
}
</script>

CSS部分


  <style lang="less" scoped>
.layout {
  height: 100%;
  padding: 0;

  ::v-deep .ant-row {
    height: 100%;

    .gutter-row {
      height: 100%;
    }
  }

  .bgwhite {
    height: 100%;
    background: #fff;
    overflow: hidden;

    .treeBox {
      padding: 15px;
      height: calc(100% - 46px);
      overflow-y: auto;
    }

    .headerText {
      line-height: 46px;
      padding: 0 20px;
      font-weight: 600;
      font-size: 15px;
    }

    ::v-deep .ant-divider-horizontal {
      margin: 0;
    }

    ::v-deep .ant-select {
      width: 100%;
    }
  }

  .top {
    padding: 15px 20px 5px;
    margin-bottom: -5px;
  }

  .mid {
    padding: 10px 20px 20px;
    .mid_header {
      ::v-deep .ant-btn {
        margin-right: 0;
      }
      .ant-btn {
        margin-right: 8px;
      }
    }
  }

  // 树
  ::v-deep .ant-tree {
    li {
      padding: 1px 0;
    }

    .ant-tree-node-content-wrapper {
      width: calc(100% - 24px);
      height: 32px;
      line-height: 32px;
    }
    span.ant-tree-switcher,
    span.ant-tree-iconEle {
      height: 32px;
      line-height: 32px;
    }
  }
}

::v-deep .ant-modal-body {
  max-height: 520px;
  overflow-y: auto;
}
</style>

标签:el,vue,const,res,ids,else,antdesign,message,表单
From: https://blog.51cto.com/u_11377693/7483556

相关文章

  • vue-day02
    模版语法html<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>Title</title><scriptsrc="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>&......
  • Vue Debug Reac 配置
    https://zhuanlan.zhihu.com/p/475999585 作为前端开发,基本每天都要调试Vue/React代码,不知道大家都是怎么调试的,但我猜大概有这么几种:不调试,直接看代码找问题console.log打印日志用ChromeDevtools的debugger来调试用VSCode的debugger来调试不同的调试方式效......
  • vue vue-devtools调试工具神器安装
    目录vuevue-devtools调试工具神器安装前言chrome商店直接安装手动安装第一步:找到vue-devtools的github项目,并将其clone到本地.vue-devtools第二步:安装项目所需要的npm包第三步:编译项目文件第四步:添加至chrome游览器vue-devtools如何使用文章转自vuevue-devtools调试工具神器安......
  • vue3videplayer播放m3u8视频流注意事项
    前言使用vue3开发项目时,碰上需要做一个视频流列表的页面,最开始是想获取所有列表数据后创建对应的video标签,这样默认获取第一帧作为封面,同时暂停视频减轻不断请求的压力。但开发后发现视频就算暂停后也会继续请求视频流,多个视频反而会导致页面卡顿。方案手动获取视频的第一......
  • Vue——模版语法、文本指令、事件指令、属性指令、style和class、条件渲染、列表渲染
    模版语法<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>Title</title><scriptsrc="./js/vue.js"></script></head><body><divid=&......
  • vue背景及快速使用
    前端介绍1.HTML(5)、CSS(3)、JavaScript(ES5、ES6、ES11):编写一个个的页面->给后端(PHP、Python、Go、Java)->后端嵌入模板语法->后端渲染完数据->返回数据给前端->在浏览器中查看2. Ajax的出现->后台发送异步请求,Render+Ajax混合3.单用Ajax(加载数据,DOM渲染页......
  • 每日一练:无感刷新页面(附可运行的前后端源码,前端vue,后端node)
    1、前言想象下,你正常在网页上浏览页面。突然弹出一个窗口,告诉你登录失效,跳回了登录页面,让你重新登录。你是不是很恼火。这时候无感刷新的作用就体现出来了。2、方案2.1redis设置过期时间在最新的技术当中,token一般都是在Redis服务器存着,设置过期时间。只要在有效时间内,重新发......
  • Vue基础
    一条件渲染指令释义v-if相当于:ifv-else相当于:elsev-else-if相当于:elseif<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>if、elseif、else</title><scriptsrc=......
  • vue2原理初探-数据代理和数据劫持
    本篇文章主要想简单聊聊vue如何实现数据修改,页面联动的底层原理。当然,篇幅有限,只是自己一些浅显的认知而已,我会从一下几个方面去聊,希望对你有所帮助。几个基础知识点数据代理数据劫持完整demo 一、几个基础知识点1.普通函数和箭头函数的区别我们知道,每个函数执行都会......
  • Vue2 Modal组件函数式调用封装(基于Ant Design Vue 组件)
    一、h函数(createElement函数)版本importVuefrom"vue";import{Modal}from"ant-design-vue";//获取扩展Modal组件functiongetModalConstructor(modalProps,childConfig){const{component,...restConfig}=childConfig;returnVue.extend({......