• 可以先看一下官网中table的自定义列模板代码
  1.  
    <template>
  2.  
    <el-table
  3.  
    :data="tableData"
  4.  
    border
  5.  
    style="width: 100%">
  6.  
    <el-table-column
  7.  
    label="日期"
  8.  
    width="180">
  9.  
    <template scope="scope">
  10.  
    <el-icon name="time"></el-icon>
  11.  
    <span style="margin-left: 10px">{{ scope.row.date }}</span>
  12.  
    </template>
  13.  
    </el-table-column>
  14.  
    <el-table-column
  15.  
    label="姓名"
  16.  
    width="180">
  17.  
    <template scope="scope">
  18.  
    <el-popover trigger="hover" placement="top">
  19.  
    <p>姓名: {{ scope.row.name }}</p>
  20.  
    <p>住址: {{ scope.row.address }}</p>
  21.  
    <div slot="reference" class="name-wrapper">
  22.  
    <el-tag>{{ scope.row.name }}</el-tag>
  23.  
    </div>
  24.  
    </el-popover>
  25.  
    </template>
  26.  
    </el-table-column>
  27.  
    <el-table-column label="操作">
  28.  
    <template scope="scope">
  29.  
    <el-button
  30.  
    size="small"
  31.  
    @click="handleEdit(scope.$index, scope.row)">编辑</el-button>
  32.  
    <el-button
  33.  
    size="small"
  34.  
    type="danger"
  35.  
    @click="handleDelete(scope.$index, scope.row)">删除</el-button>
  36.  
    </template>
  37.  
    </el-table-column>
  38.  
    </el-table>
  39.  
    </template>
  40.  
     
  41.  
    <script>
  42.  
    export default {
  43.  
    data() {
  44.  
    return {
  45.  
    tableData: [{
  46.  
    date: '2016-05-02',
  47.  
    name: '王小虎',
  48.  
    address: '上海市普陀区金沙江路 1518 弄'
  49.  
    }, {
  50.  
    date: '2016-05-04',
  51.  
    name: '王小虎',
  52.  
    address: '上海市普陀区金沙江路 1517 弄'
  53.  
    }, {
  54.  
    date: '2016-05-01',
  55.  
    name: '王小虎',
  56.  
    address: '上海市普陀区金沙江路 1519 弄'
  57.  
    }, {
  58.  
    date: '2016-05-03',
  59.  
    name: '王小虎',
  60.  
    address: '上海市普陀区金沙江路 1516 弄'
  61.  
    }]
  62.  
    }
  63.  
    },
  64.  
    methods: {
  65.  
    handleEdit(index, row) {
  66.  
    console.log(index, row);
  67.  
    },
  68.  
    handleDelete(index, row) {
  69.  
    console.log(index, row);
  70.  
    }
  71.  
    }
  72.  
    }
  73.  
    </script>
  74.  
     

点击单元格弹出框可以使用template-scope方式实现

  • 父组件
  1.  
    <el-table
  2.  
    :data="tableData"
  3.  
    border
  4.  
    style="width: 100%">
  5.  
    <el-table-column
  6.  
    label="编号"
  7.  
    prop = "number"
  8.  
    width="180">
  9.  
    <template scope="scope">
  10.  
    <div style="color:red;text-decoration:underline;cursor:pointer;" @click="getMore(scope.row)">{{ scope.row.date }}</div>
  11.  
    </template>
  12.  
    </el-table-column>
  13.  
    <el-table-column
  14.  
    label="名称"
  15.  
    prop = "name"
  16.  
    width="180">
  17.  
    <template scope="scope">
  18.  
    <div style="color:red;text-decoration:underline;cursor:pointer;" @click="getMore2(scope.row)">{{ scope.row.date }}</div>
  19.  
    </template>
  20.  
    </el-table-column>
  21.  
    </el-table>
  22.  
     
  23.  
    <el-dialog :visible-sync="getA">
  24.  
    <my-component :rowaa=row></my-component>
  25.  
    </el-dialog>
  26.  
    <el-dialog :visible-sync="getB">
  27.  
    <my-component2 :rowaa=row></my-component2>
  28.  
    </el-dialog>
  29.  
     
  30.  
    <script>
  31.  
    import myComponent from './mycomponent'
  32.  
    import myComponent2 form './mycomponent2'
  33.  
    export default {
  34.  
    data() {
  35.  
    return {
  36.  
    tableData : [
  37.  
    {"number" : 1,"name":"y"},
  38.  
    {"number" : 2,"name":"x"},
  39.  
    ],
  40.  
    getA : false,
  41.  
    getB : false,
  42.  
    row : ''
  43.  
    }
  44.  
    },
  45.  
    components: {
  46.  
    'my-component' : myComponent,
  47.  
    'my-component2' : myComponent2
  48.  
    },
  49.  
    methods : {
  50.  
    getMore(row) {
  51.  
    this.getA = true
  52.  
    this.row = row
  53.  
    },
  54.  
    getMore2(row) {
  55.  
    this.getB = true
  56.  
    this.row = row
  57.  
    }
  58.  
    }
  59.  
    }
  60.  
    </script>
  61.  
     
  • 子组件 mycomponent
  1.  
    <div>{{formData}}</div>
  2.  
     
  3.  
    <script>
  4.  
    export default {
  5.  
    props: ['rowaa'],
  6.  
    data() {
  7.  
    return {
  8.  
    formData:''
  9.  
    }
  10.  
    },
  11.  
    created() {
  12.  
    this.getData()
  13.  
    },
  14.  
    watch : {
  15.  
    'rowaa' : 'getData'
  16.  
    },
  17.  
    methods: {
  18.  
    getData() {
  19.  
    //从后台获取数据逻辑 model.CacheModel.get('api/' + this.rowaa + '.json')
  20.  
    //通过this.rowaa就可以获取传过来的值
  21.  
    this.formData = 333
  22.  
    }
  23.  
    }
  24.  
    }
  25.  
    </script>
  26.  
     

问题解决

  • 可以使用template+slot插值进行管理
  • 点击找到当前行的信息,然后再根据该信息在子组件中请求数据
  • 也试过通过点击行的事件,判断在哪一个单元格然后处理事件,这样也可以,但如果在表格中列存放的内容发生变化又得重新调整
  • 也试过dialog弹出框直接写在当前单元格的template中,就像官网中例子一样,但是这样会在点击时触发多次(次数与当前页展示的数量一致)

vue+elementui怎样点击table中的单元格触发事件--弹框的更多相关文章

  1. elmentUI为table中的单元格添加事件

    <el-main> <el-tabs v-model="curTab" type="card"> <!-- tab签 --> ...

  2. css实现table中td单元格鼠标悬浮时显示更多内容

    table中,td单元格无法显示下全部内容,需要在鼠标hover时显示全部内容. 正常显示样式: 鼠标hover时: html: <td>displayAddress<span cl ...

  3. 使用js合并table中的单元格

    用primefaces做的报表,领导要求合并相同内容的单元格,但是primefaces没有找到可以合并单元格的组件,想来想去,只有页面加载后用js合并了. http://blog.csdn.net/d ...

  4. POI写docx文件table中的单元格水平、垂直对齐

    核心示例代码 垂直对齐 XWPFTableCell cell = table.getRow(i).getCell(j); cell.setVerticalAlignment(XWPFTableCell ...

  5. 【表格设置】HTML中合并单元格,对列组合应用样式,适应各浏览器的内容换行

    1.常用表格标签 普通    <table>           |           <tr>          |           |          <th ...

  6. 点击table中的某一个td,获得这个tr的所有数据

    功能: 点击table中的某一个td,获得这个tr的所有数据 效果图 <html> <head> <script> function getData2(elemen ...

  7. JS去遍历Table的所有单元格中的内容

    用JS去遍历Table的所有单元格中的内容,可以用如下JS代码实现 function GetInfoFromTable(tableid) { var tableInfo = ""; ...

  8. JS遍历Table的所有单元格内容

    用JS去遍历Table的所有单元格中的内容,可以用如下JS代码实现: 这个方法的参数是唯一标识Table的id,用document对象的获取. function GetInfoFromTable(ta ...

  9. winform中dataGridView单元格根据值设置新值,彻底解决绑定后数据类型转换的困难

    // winform中dataGridView单元格在数据绑定后,数据类型更改困难,只能迂回实现.有时候需要将数字变换为不同的文字描述,就会出现int32到string类型转换的异常,借助CellFo ...

  10. 读取Excel文件中的单元格的内容和颜色

    怎样读取Excel文件中的单元格的内容和颜色 先创建一个Excel文件,在A1和A2中随意输入内容,设置A1的字体颜色为红色,A2的背景为黄色.需要 using Excel = Microsoft.O ...

随机推荐

  1. Yacc笔记

    语义动是一个C语句的序列 $$ 表是和相应产生式头的非终结符号关联的属性值 $i  表示和相应产生式体中第 i 个文法符号(终结符或非终结符号)关联的属性值 按照产生式规约时会执行关联的语义动作 对于 ...

  2. CentOS上配合nginx 使用 Certbot 生成SSL证书

    您可以使用 Let's Encrypt 来申请免费的 SSL 证书.以下是在 CentOS 上安装 Certbot 并使用它来获取 Let's Encrypt SSL 证书的步骤: 安装 Certbo ...

  3. DDCA —— 内存一致性

    1. 同步(Synchronization) 1.1 构造锁(Locks) 原子(atomic)执行:应用程序的某些部分必须独占执行(原子性),这意味着在这些部分执行期间,其他并行进程无法访问或修改相 ...

  4. Pytest接口自动化测试框架Python自动化测试开发

    一.引言 在软件开发过程中,接口测试是确保软件各个组件之间数据传输和功能交互正常工作的重要环节.通过接口测试,可以提高软件的整体质量和稳定性.Pytest是一个流行的Python自动化测试框架,提供了 ...

  5. 痞子衡嵌入式:MCUXpresso IDE下C++源文件中嵌套定义的复合数据类型命名空间认定

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下C++源文件中嵌套定义的复合数据类型命名空间认定. 痞子衡之前写过一篇文章 <MCUXpresso ...

  6. R数据分析:冲击流图与热图的做法以及多图布局

    今天看了一篇新冠肺炎相关后遗症的文章,主要探讨新冠住院病人一年后的后遗症情况,文章的统计分析很简单,不过结果展示中的两个图我觉的大家可以学一学,原文如下 Rivera-Izquierdo, M., L ...

  7. ASP.NET Core IHostBuilder

    HostBuilder 很显然,HostBuildr 就是用来构建 Host 的构建器. IHostBuilder 定义 通过 Build() 方法,构建器返回构建的 IHost 对象实例. 具体怎么 ...

  8. Failed to start bean 'webServerStartStop'; nested exception is org.springframework.beans.FatalBeanException: ServletWebServerFactory implementation

    使用jeecgboot报错 jeecg单测跑不起来,报错如下 Failed to start bean 'webServerStartStop'; nested exception is org.sp ...

  9. Anaconda中的Spyder软件设置为中文教程

     Anaconda中的Spyder软件设置为中文教程 第一步:工具栏中Tools --> Preferences 第二步:第二栏的 Application--> 第二个选项卡Advance ...

  10. [转]Makefile教程

    从0开始教你编写Makefile文件 跟我一起写Makefile-陈皓2005.pdf:链接: https://pan.baidu.com/s/1kKPfosCiPQONyZ1oeCmuAA 提取码: ...