最近做一个商城系统的订单管理,用到IviewUI框架的表格table组件,做一个勾选功能,但这需要设置只能单选,但iview官方表格勾选里checkbox是多选,如何把多选变成单选。
先看下iview官方表格table组件文档:http://v4.iviewui.com/components/table
在网上找了很多方法,有说用render渲染样式后控制,也有说用$refs.selection.objData[index]._isChecked = false设置成单独选。都试了都不行。再仔细看了官方有文档,有@on-select方法和_checked结合,就想着点击时把其他设置成false,当前checkbox设置成相反的。最终可以实现了。
先看下效果图:
以下是完整的iview UI表格table组件checkbox多选设置单选代码:
<!DOCTYPE html><html><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><!-- import Vue.js --><script type="text/javascript" src="https://unpkg.com/vue@2.6.14/dist/vue.js"></script><!-- import stylesheet --><link rel="stylesheet" type="text/css" href="https://unpkg.com/view-design@4.7.0/dist/styles/iview.css"><!-- import iView --><script type="text/javascript" src="https://unpkg.com/view-design@4.7.0/dist/iview.min.js"></script></head><body><div id="app"> <i-table border ref="selection" :columns="columns4" :data="data1" @on-select="TableSelectRow" ></i-table> <Button @click="handleSelectAll(true)">全选</Button> <Button @click="handleSelectAll(false)">取消全选</Button></div><script> new Vue({
el: '#app',
data: {
visible: false,
columns4: [
{
type: 'selection',
width: 60,
align: 'center' },
{
title: 'Name',
key: 'name' },
{
title: 'Age',
key: 'age' },
{
title: 'Address',
key: 'address' }
],
data1: [
{
name: 'John Brown',
age: 18,
address: 'New York No. 1 Lake Park',
date: '2016-10-03' },
{
name: 'Jim Green',
age: 24,
address: 'London No. 1 Lake Park',
date: '2016-10-01',
_checked: false },
{
name: 'Joe Black',
age: 30,
address: 'Sydney No. 1 Lake Park',
date: '2016-10-02',
_checked: false },
{
name: 'Jon Snow',
age: 26,
address: 'Ottawa No. 2 Lake Park',
date: '2016-10-04' }
]
},
methods: {
show: function () {
this.visible = true;
},
handleSelectAll (status) {
this.$refs.selection.selectAll(status);
},
TableSelectRow(selection, row)
{
console.log('row:',row)
var data1 = this.data1;
data1.forEach(function(item){
if(item.name==row.name)
{
console.log(row.name)
item._checked = !item._checked
}
else item._checked = false })
console.log('data1:',data1)
this.data1 = data1
}
}
})
</script></body></html>复制




