首页 > 其他分享 >elementUI 的el-dialog作为子组件,父组件如何控制其关闭的按钮

elementUI 的el-dialog作为子组件,父组件如何控制其关闭的按钮

时间:2023-12-22 11:26:32浏览次数:28  
标签:el const deviceName elementUI item deviceId 组件 id recentOnlineTime

这里有三点需要说明:

1. 使用:before-close="closeHandle" 将其 $emit() 出去

2. 取消按钮 也需要$emeit出去

3. 控制对话框显示隐藏的变量需要props给父组件来传值,这个相当重要,不然控制不了对话框的显示隐藏

4.1,2步骤是为了在子组件不再重复操作显示隐藏的变量,vue会报错

<template>
  <el-dialog
    title="选择设备"
    width="1000px"
    class="select-device-dialog"
    v-model="dialogShow"
    destroy-on-close
    :close-on-click-modal="false"
    :modal-orgend-to-body="false"
    :append-to-body="true"
    :before-close="handleClose"
  >
    <div class="dialog-box">
      <div class="search-box">
        <el-select
          placeholder="请选择产品分类"
          class="select-product-class"
          v-model="searchForm.productClass"
          multiple
          clearable
          collapse-tags
          collapse-tags-tooltip
          :max-collapse-tags="2"
        >
          <el-option label="小米产品" value="1" />
          <el-option label="涂鸦产品" value="2" />
          <el-option label="建大仁建" value="3" />
          <el-option label="Modbus网关" value="4" />
          <el-option label="通用产品" value="5" />
        </el-select>
        <el-select
          placeholder="请选择产品"
          class="select-product"
          v-model="searchForm.product"
          multiple
          clearable
          collapse-tags
          collapse-tags-tooltip
          :max-collapse-tags="2"
        >
          <el-option label="窗帘电机" value="1" />
          <el-option label="人体存在传感器" value="2" />
          <el-option label="三开开关" value="3" />
          <el-option label="双开开关" value="4" />
          <el-option label="单开开关" value="5" />
          <el-option label="空调控制器" value="6" />
          <el-option label="湿度传感器" value="7" />
          <el-option label="温度传感器" value="8" />
          <el-option label="通用产品" value="9" />
        </el-select>
        <el-select
          placeholder="请选择设备组"
          class="select-device-group"
          v-model="searchForm.deviceGroup"
          multiple
          clearable
          collapse-tags
          collapse-tags-tooltip
          :max-collapse-tags="3"
        >
          <el-option label="公共设备组" value="1" />
        </el-select>
        <el-input
          v-model="searchForm.deviceName"
          class="input-device"
          placeholder="请输入设备名称"
          clearable
        />
        <el-input
          v-model="searchForm.deviceId"
          class="input-device"
          placeholder="请输入设备ID"
          clearable
        />
        <div class="">
          <span class="btn btn-deault" @click="search">查询</span>
          <span class="btn btn-plain" @click="reset">重置</span>
        </div>
      </div>
      <el-table style="width: 100%" max-height="300" :data="deviceList">
        <el-table-column prop="deviceName" label="设备名称">
          <template #default="{ row }">
            <span class="orange-text" @click="selectDevice(row)">{{
              row.deviceName
            }}</span>
          </template>
        </el-table-column>
        <el-table-column prop="deviceId" label="设备ID" />
        <el-table-column prop="status" label="状态">
          <template #default="{ row }">
            <span v-if="row.status === '1'" style="color: #55bc8a">已启用</span>
            <span v-else style="color: #f56c6c">已禁用</span>
          </template>
        </el-table-column>
        <el-table-column prop="onLineStatus" label="在线状态" />
        <el-table-column prop="describe" label="描述" />
        <el-table-column prop="recentOnlineTime" label="最近在线时间" />
        <el-table-column fixed="right" label="操作" width="100">
          <template #default="{ row }">
            <el-button link type="warning" @click="detailClick(row)"
              >详情</el-button
            >
          </template>
        </el-table-column>
      </el-table>
    </div>
  </el-dialog>
</template>

<script setup>
import { ref, watch, computed, nextTick } from 'vue'
import { useRouter } from 'vue-router'
const router = useRouter()
const props = defineProps({
  isShow: {
    type: Boolean,
    default: false
  }
})
const searchForm = ref({
  productClass: '',
  product: '',
  deviceGroup: '',
  deviceName: '',
  deviceId: ''
})

const emits = defineEmits(['update:isShow', 'getDevice'])
const dialogShow = computed({
  get: () => props.isShow,
  set: (value) => {
    emits('update:isShow', value)
  }
})

const deviceList = ref([
  {
    id: '11',
    deviceName: '会议室东窗帘',
    deviceId: 'cl2',
    status: '1',
    onLineStatus: '',
    describe: '',
    recentOnlineTime: ''
  },
  {
    id: '12',
    deviceName: '办公室开关',
    deviceId: 'cl2',
    status: '1',
    onLineStatus: '',
    describe: '',
    recentOnlineTime: ''
  },
  {
    id: '13',
    deviceName: '人体感应一',
    deviceId: 'cl2',
    status: '1',
    onLineStatus: '',
    describe: '',
    recentOnlineTime: ''
  },
  {
    id: '14',
    deviceName: '大会议室开关一',
    deviceId: 'rt1',
    status: '1',
    onLineStatus: '',
    describe: '',
    recentOnlineTime: ''
  },
  {
    id: '15',
    deviceName: '走廊开关一',
    deviceId: 'switch6',
    status: '1',
    onLineStatus: '',
    describe: '',
    recentOnlineTime: ''
  },
  {
    id: '16',
    deviceName: '餐厅三空调',
    deviceId: 'kt6',
    status: '1',
    onLineStatus: '',
    describe: '',
    recentOnlineTime: ''
  }
])
const selectDevice = (item) => {
  if (item) {
    emits('getDevice', item)
  }
}
const search = () => {
  console.log('search')
}
const reset = () => {
  searchForm.value = {
    productClass: '',
    product: '',
    deviceGroup: '',
    deviceName: '',
    deviceId: ''
  }
}

const handleClose = () => {
  emits('getDevice', {})
}
const detailClick = (row) => {
  const newUrl = router.resolve({
    name: 'entity-device'
  })
  window.open(newUrl.href, '_blank')
  localStorage.setItem('deviceId', row.id)
}
</script>

<style lang="scss" scoped>
.search-box {
  display: flex;
  flex-wrap: wrap;
  .el-input,
  .el-select {
    width: 310px;
    margin: 0 10px 10px 0;
  }
  .btn-deault {
    margin-left: 0;
  }
}
</style>

<style lang="scss">
.select-device-dialog {
  .el-dialog__body {
    padding-top: 3px;
    padding-bottom: 20px;
  }
}
</style>

父组件:

const getDevice = (item) => {   selectDeviceVisible.value = false   if (item.deviceName) {     currentRow.value.device = item.deviceName   } }

标签:el,const,deviceName,elementUI,item,deviceId,组件,id,recentOnlineTime
From: https://www.cnblogs.com/guwufeiyang/p/17920856.html

相关文章

  • el-select自定义指令用于触底加载分页请求options数据(附上完整代码和接口可直接用)
    问题描述某些情况下,下拉框需要做触底加载,发请求,获取option的数据为了方便复用,笔者封装了一个自定义指令另外也提供了一个简单的接口,用于演示我们先看看效果图效果图思路分析注意事项一el-select要不嵌入到body中为何,不嵌入到body标签中呢?答曰,更加方便自定义指令管理......
  • 十八、组件-容器组件-column、row、flex
    @Entry@ComponentstructColumExample{build(){Column({space:10}){Column(){Column().width('50%').height(30).backgroundColor(Color.Blue)Column().width('60%').height(40).backgroundColor(Color.Brown)......
  • element ui 表格与锚点定位
    父组件表格页面代码:<template> <divclass="wrapper">  <divclass="overview-box">   <divclass="box-name">    <divclass="flag"/>    标的事件   </div>   <pclass......
  • element-plus的type类型为daterange的时候限制时间选择
    对于ElementPlus的日期时间范围选择组件(el-date-picker的type设置为"daterange"),你可以使用:picker-options属性来设置选项,通过disabledDate函数来禁止选择当前时间之前的日期。下面是一个el-date-picker(type为"daterange")的示例,它禁止选择今天之前的日期:<el-date-......
  • 无涯教程-Haskell - Nested if-else 语句函数
    以下代码显示了如何在Haskell中使用嵌套的if-else语句-main=doletvar=26ifvar==0thenputStrLn"Numberiszero"elseifvar`rem`2==0thenputStrLn"NumberisEven"elseputStrLn"NumberisOdd"在上面的示例中......
  • Panel 管理
       样本公司代码      55   365      53   kurun      59   InsightWorks      52   Ipanel   优先样本公司      ・365      ・Paneland      ・百数来      ・MDQ   样本公司开......
  • 官宣!DevExpress Blazor UI组件,支持全新的.NET 8渲染模式
    DevExpress BlazorUI组件使用了C#为BlazorServer和BlazorWebAssembly创建高影响力的用户体验,这个UI自建库提供了一套全面的原生BlazorUI组件(包括PivotGrid、调度程序、图表、数据编辑器和报表等)。.NET8为Blazor引入了令人兴奋的重大变化,统一了它的托管模型,并采用了服务器......
  • 【c# winform】devexpress treeList右键菜单添加按钮
    本文提供俩种不需要手动添加编辑控件方法。方法一:创建新的右键菜单添加“执行选择”按钮,且抑制TreeList自带菜单结果展示: 代码: privatevoidForm1_Load(objectsender,EventArgse){CreateBarButtonItem();}privatevoidCreateBarButtonItem(){//创建右键......
  • C++ Qt开发:StandardItemModel数据模型组件
    Qt是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍StandardItemModel数据模型组件的常用方法及灵活运用。QStandardItemModel是Qt中用于存储标准......
  • Map+函数式接口去掉if-else
    判断条件放在key中对应的业务逻辑放在value中这样子写的好处是非常直观,能直接看到判断条件对应的业务逻辑代码:importcom.wing.service.QueryGrantTypeService;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.web.bind.......