V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
qiyong
V2EX  ›  问与答

vue+elementUI 表格里每一行的 checkbox 如何按照点击顺序赋值

  •  
  •   qiyong · 2021-02-09 10:46:17 +08:00 · 1407 次点击
    这是一个创建于 1412 天前的主题,其中的信息可能已经有所发展或是发生改变。

    比如这样 每行都有 checkbox 如果先点击第一行的,就为那个 checkbox 后面的值赋 1,如果再点第四行的 就为那个赋 2,按照点击顺序来,VUE 会响应,所以我不知道如何实现这个功能 提前祝大火新年快乐!

    第 1 条附言  ·  2021-02-09 12:15:37 +08:00
    感谢各位 但是怎么在 checkbox 里判断当前是否是选中状态
    ![]( https://i.bmp.ovh/imgs/2021/02/7087096f75a9a21a.png)
    第 2 条附言  ·  2021-02-09 14:16:51 +08:00
    好起来了 全都好起来了 谢谢大家!
    11 条回复    2021-02-09 14:11:27 +08:00
    qiyong
        1
    qiyong  
    OP
       2021-02-09 10:46:44 +08:00
    qiyong
        2
    qiyong  
    OP
       2021-02-09 10:47:03 +08:00
    azcvcza
        3
    azcvcza  
       2021-02-09 10:57:21 +08:00   ❤️ 1
    行还是列我建议你说清楚一点,第一行和第四行都不是一个数据,为什么 checkbox 之间要关联在一起,然后你统计一个勾选的 checkbox 次数也让人不解,要是以新增 /编辑 /列表 /查询,存为{add:false,edit:false,list:false,query:false};或者[0,0,0,0],或者直接存成二进制'0000','1000','1100','0100',都可以理解,但为什么是统计次数?
    liyang5945
        4
    liyang5945  
       2021-02-09 11:02:17 +08:00   ❤️ 1
    组件内定义一个变量,比如 tempIndex,初始值设为 0,每一行的绑定 checkbox 事件,选中 tempIndex+1,如果反选-1,再把这个值赋给每一行的对象,比如 clickIndex,row.clickIndex = this.tempIndex
    qiyong
        5
    qiyong  
    OP
       2021-02-09 11:02:53 +08:00
    @azcvcza 我想让他有个先后顺序,想写一个代码生成器,就拿新增来说,新增表单不是得有个填写顺序嘛,就是先填名再填身份证最后填写备注这个意思,就是配置展示顺序,可以选择手写顺序,但那样太不智能了,我想直接按点击来弄顺序
    qiyong
        6
    qiyong  
    OP
       2021-02-09 11:11:24 +08:00
    我是 Java 后端,VUE 学的还不咋多,问的问题太弱智的话见谅
    EaSonTreville
        7
    EaSonTreville  
       2021-02-09 11:19:42 +08:00   ❤️ 1
    <el-table @selection-change="handleSelectionChange">


    handleSelectionChange(val) {
    let count = 0
    val.forEach( item => {
    let index = this.tableData.findIndex( element => element.id === item.id )
    this.tableData[index].clickIndex = count
    count++
    })
    }

    LZ 是这个意思吗?
    azcvcza
        8
    azcvcza  
       2021-02-09 11:20:23 +08:00   ❤️ 1
    一般前端搞的表格数据结构大概就是
    ```
    var table_data = [
    {
    column_id: '',
    column_name:'',
    column_desc:'',
    column_real_type:'',
    column_java_type:'',
    column_auth: {
    add: false,
    edit: false,
    list: false,
    query: false,
    },
    column_query_type: 0,
    column_required: false,
    column_view_type: '',
    }.

    ...
    ]

    ```
    vue 的 template 大概是
    ```
    //假设行点击是 handleRowClick
    <v-table model="table_data" @rowClick="handleRowClick" />

    ```
    一般做法不就是在 handleRowClick 里拿到对应的 column_id (假设有唯一标识),再去修改 data 里的值吗
    miv
        9
    miv  
       2021-02-09 11:49:36 +08:00   ❤️ 1
    弄一个这个组件共享的全局变量,初始化为 0 。
    每一行点击事件触发以后,如果是选中 checkbox,把全局变量保存到 row 信息里面,然后全局变量++。
    每一行点击事件触发以后,如果是取消 checkbox,移除原先的 row 信息,然后全局变量--,恢复一下。
    qiyong
        10
    qiyong  
    OP
       2021-02-09 13:49:37 +08:00
    @miv 咋判断是取消还是选中呢?有对应的事件吗
    <el-table-column label="必填" min-width="5%">
    <template v-slot="scope">
    <el-checkbox true-label="1" v-model="scope.row.isRequired" @change="scope.row.rowRequiredIndex = requiredIndex++">
    <el-badge class="mark" :value=scope.row.rowRequiredIndex type="primary"/>
    </el-checkbox>
    </template>
    </el-table-column>
    miv
        11
    miv  
       2021-02-09 14:11:27 +08:00
    @qiyong #10 看文档啊,文档里面有说的。 @change 绑定一个方法,这是基础问题了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1068 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 18:09 · PVG 02:09 · LAX 10:09 · JFK 13:09
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.