Iview UI Table Cell - PullRequest
       11

Iview UI Table Cell

0 голосов
/ 14 мая 2018

Как я могу получить доступ к данным ячейки в таблице iview библиотеки для Vuejs, когда я нажимаю на нее?Мне нужно значение таблицы ячеек и заголовок столбца после этого изменить таблицу ячеек CSS.Например, если я щелкну в ячейке, и она станет красной, в другой ячейке она станет зеленой

1 Ответ

0 голосов
/ 25 июня 2018
<template>
    <Table border :columns="columns7" :data="data6"></Table>
</template>
<script>
    export default {
        data () {
            return {
                columns7: [
                    {
                        title: 'Age',
                        key: 'age'
                    },
                    /* blah blah blah...*/
                    {
                        title: 'Action',
                        key: 'action',
                        width: 150,
                        align: 'center',
                        render: (h, params) => {
                            return h('div', [
                                h('Button', {
                                    props: {
                                        type: 'primary',
                                        size: 'small'
                                    },
                                    style: {
                                        marginRight: '5px'
                                    },
                                    on: {//here you can pass event handlers
                                        click: () => {
                                            this.show(params.index)
                                        }
                                    }
                                }, 'View'),
                                h('Button', {
                                    props: {
                                        type: 'error',
                                        size: 'small'
                                    },
                                    on: {
                                        click: () => {
                                            this.remove(params.index)
                                        }
                                    }
                                }, 'Delete')
                            ]);
                        }
                    }
                ],
                data6: [
                    {
                        name: 'John Brown',
                        age: 18,
                        address: 'New York No. 1 Lake Park'
                    },
                    {
                        name: 'Jim Green',
                        age: 24,
                        address: 'London No. 1 Lake Park'
                    },
                    {
                        name: 'Joe Black',
                        age: 30,
                        address: 'Sydney No. 1 Lake Park'
                    },
                    {
                        name: 'Jon Snow',
                        age: 26,
                        address: 'Ottawa No. 2 Lake Park'
                    }
                ]
            }
        },
        methods: {
            show (index) {
                this.$Modal.info({
                    title: 'User Info',
                    content: `Name:${this.data6[index].name}<br>Age:${this.data6[index].age}<br>Address:${this.data6[index].address}`
                })
            },
            remove (index) {
                this.data6.splice(index, 1);
            }
        }
    }
</script>

Вы можете предоставить функцию рендера в определении столбцов.(А в функции рендеринга вы можете «связать» получателей событий). jsfiddle , iview doc , Vue - функции рендеринга

...