我有一个字段集,其中包含一个具有 3 个检查列的网格:领导者、成员和查看者。如果用户点击Leader 复选框中的复选框,则Member 和Viewer 复选框中的相应复选框应该被禁用(即用户不应该能够点击这些复选框)。如果用户单击“成员”或“查看者”检查列中的复选框,情况也是如此;其他复选框不应该是可点击的。任何想法如何去做?
问问题
2591 次
2 回答
1
我能够使用record.set 解决这个问题。我的代码如下:
Ext.Loader.setConfig({enabled: true, paths:{'Ext.ux': 'ext/js/ux'}});
Ext.require([
'Ext.grid.*',
'Ext.data.*',
'Ext.ux.grid.HeaderToolTip',
'Ext.ux.CheckColumn'
]);
Ext.onReady(function () {
Ext.tip.QuickTipManager.init();
var teststore = Ext.create('Ext.data.ArrayStore', {
fields: [
{name: 'UserID', type: 'asUCString'},
{name: 'Name', type: 'asUCString'},
{name: 'Role', type: 'asUCString'},
{name: 'Leader', type: 'bool'},
{name: 'Member', type: 'bool'},
{name: 'Viewer', type: 'bool'}
],
data: [
['1', 'Hans Hansel', 'Customer/Freelancer', false, false, false],
['2', 'Doreen Duck', 'Consultant', false, false, false],
['3', 'Gerald Goose', 'Client', false, false, false],
['4', 'Frederic Fitzgerald', 'Super User IT', false, false, false],
['5', 'Aimee Anselm', 'Administrator', false, false, false]
]
});
var grid = Ext.create('Ext.grid.Panel', {
id: 'setPermissionsGrid',
title: '',
store: teststore, //Ext.data.StoreManager.lookup('simpsonsStore'),
plugins: ['headertooltip'],
//selType: 'checkboxmodel',
columns: [
{ text: 'Name', dataIndex: 'Name', width: 120},
{ text: 'Role', dataIndex: 'Role', width: 125},
{ text: 'Leader', dataIndex: 'Leader', xtype: 'checkcolumn', listeners: {'checkchange' : function(column, recordIndex, checked) {var record = teststore.getAt(recordIndex); record.set('Member', false); record.set('Viewer', false); }},width: 68, tooltip: '<b>Team Leader Rights:</b> '},
{ text: 'Member', dataIndex: 'Member', xtype: 'checkcolumn', listeners: {'checkchange' : function(column, recordIndex, checked) {var record = teststore.getAt(recordIndex); record.set('Leader', false); record.set('Viewer', false); }},width: 68, tooltip: '<b>Team Member Rights:</b> '},
{ text: 'Viewer', dataIndex: 'Viewer', xtype: 'checkcolumn', listeners: {'checkchange' : function(column, recordIndex, checked) {var record = teststore.getAt(recordIndex); record.set('Leader', false); record.set('Member', false); }},width: 68, tooltip: '<b>Team Viewer Rights:</b> '}
],
height: 219,
width: 450,
renderTo: Ext.getBody()
于 2012-11-12T14:07:43.510 回答
1
RadioGroup 是不可行的,因为应用程序需要允许用户检查多个复选框(在检查列中)。我已经部分解决了这个问题:现在,如果我单击领导者检查列中的任何复选框,然后单击查看器或成员检查列中的复选框,领导者检查列中的勾号就会消失。唯一的问题是,当前如果用户单击 Member 或 Viewer 复选框中的 ANY 复选框,那么 Leader 复选框中的任何选中的复选框都将变为未选中状态。但是,我只想取消选中对应的复选框(即同一行中的复选框)。这是检查列的代码,包含检查列的网格和存储:
<html>
<head>
<link rel="stylesheet" type="text/css" href="ext/resources/css/ext-all.css" />
<link rel="stylesheet" type="text/css" href="ext/js/ux/css/CheckHeader.css" />
<script type="text/javascript" src="ext/js/bootstrap.js"></script>
</head>
<body>
<script type="text/javascript">
Ext.Loader.setConfig({enabled: true, paths:{'Ext.ux': 'ext/js/ux'}});
//Ext.Loader.setPath('Ext.ux', 'ext/js/ux');
Ext.require([
'Ext.grid.*',
'Ext.data.*',
'Ext.ux.grid.HeaderToolTip',
'Ext.ux.CheckColumn'
]);
Ext.onReady(function () {
Ext.tip.QuickTipManager.init();
var teststore = Ext.create('Ext.data.ArrayStore', {
fields: [
{name: 'UserID', type: 'asUCString'},
{name: 'Name', type: 'asUCString'},
{name: 'Role', type: 'asUCString'},
{name: 'Leader', type: 'bool'},
{name: 'Member', type: 'bool'},
{name: 'Viewer', type: 'bool'}
],
data: [
['1', 'Hans Hansel', 'Customer/Freelancer', false, false, false],
['2', 'Doreen Duck', 'Consultant', false, false, false],
['3', 'Gerald Goose', 'Client', false, false, false],
['4', 'Frederic Fitzgerald', 'Super User IT', false, false, false],
['5', 'Aimee Anselm', 'Administrator', false, false, false]
]
});
var grid = Ext.create('Ext.grid.Panel', {
id: 'setPermissionsGrid',
title: '',
store: teststore,
plugins: ['headertooltip'],
columns: [
{ text: 'Name', dataIndex: 'Name', width: 120},
{ text: 'Role', dataIndex: 'Role', width: 125},
{ text: 'Leader', dataIndex: 'Leader', xtype: 'checkcolumn', listeners: {'checkchange' : function() {for (var i in teststore.data.items) {teststore.data.items[i].set('Member', false); teststore.data.items[i].set('Viewer', false);}} },width: 68, tooltip: 'Leader'},
{ text: 'Member', dataIndex: 'Member', xtype: 'checkcolumn', listeners: {'checkchange' : function() {for (var i in teststore.data.items) {teststore.data.items[i].set('Leader', false); teststore.data.items[i].set('Viewer', false);}} },width: 68, tooltip: 'Member'},
{ text: 'Viewer', dataIndex: 'Viewer', xtype: 'checkcolumn', listeners: {'checkchange' : function() {for (var i in teststore.data.items) {teststore.data.items[i].set('Leader', false); teststore.data.items[i].set('Member', false);}} },width: 68, tooltip: 'Viewer'}
],
height: 219,
width: 450,
renderTo: Ext.getBody()
});
于 2012-11-09T15:26:50.693 回答