Ich habe ein Dijit.Tree-Objekt erstellt, wo jeder Knoten ein Kontrollkästchen ist. Wenn Sie den übergeordneten Knoten auswählen/abwählen, werden die untergeordneten Knoten ausgewählt/abgewählt; Wenn eines der untergeordneten Elemente deaktiviert ist, wird das übergeordnete Element deaktiviert. Wenn alle Kinder ausgewählt sind, wird der Elternteil ausgewählt. Es funktioniert vollkommen in Ordnung.
Ich brauche es jedoch für die Tastatur zugänglich. Wenn ich zu den Baumknoten navigiere und die Leertaste oder die Eingabetaste drücke, passiert nichts.Dojo Dijit Baum mit Checkbox ist nicht Tastatur zugänglich
Ich habe versucht, Tabindex und Aria-Rolle zu der Checkbox (programmgesteuert), aber es hat nicht funktioniert. Hier
ist die Geige - http://jsfiddle.net/pdabade/pyz9Lcpv/65/
require([
"dojo/_base/window", "dojo/store/Memory",
"dijit/tree/ObjectStoreModel",
"dijit/Tree", "dijit/form/CheckBox", "dojo/dom",
"dojo/domReady!"
], function(win, Memory, ObjectStoreModel, Tree, checkBox, dom) {
// Create test store, adding the getChildren() method required by ObjectStoreModel
var myStore = new Memory({
data: [{
id: 'allDocuments',
name: 'All Documents'
}, {
id: 'inboxDocuments',
name: 'Inbox Documents',
parent: 'allDocuments'
}, {
id: 'outboxDocuments',
name: 'Outbox Documents',
parent: 'allDocuments'
}, {
id: 'draftDocuments',
name: 'Draft Documents',
parent: 'allDocuments'
}, {
id: 'finalDocuments',
name: 'Final Documents',
parent: 'allDocuments'
}],
getChildren: function(object) {
return this.query({
parent: object.id
});
}
});
// Create the model
var myModel = new ObjectStoreModel({
store: myStore,
query: {
id: 'allDocuments'
}
});
// Create the Tree.
var tree = new Tree({
model: myModel,
autoExpand: true,
getIconClass: function(item, opened) {
// console.log('tree getIconClass', item, opened);
// console.log('tree item type', item.id);
},
onClick: function(item, node, event) {
//node._iconClass= "dijitFolderClosed";
//node.iconNode.className = "dijitFolderClosed";
var _this = this;
console.log(item.id);
var id = node.domNode.id,
isNodeSelected = node.checkBox.get('checked');
dojo.query('#' + id + ' .dijitCheckBox').forEach(function(node) {
dijit.getEnclosingWidget(node).set('checked', isNodeSelected);
});
if (item.id != 'allComments') {
if (!isNodeSelected) {
var parent = node.tree.rootNode; // parent node id
//console.log(node);
parent.checkBox.set('checked', false);
} else {
var parent = node.tree.rootNode;
var selected = true;
var i = 0;
dojo.query('#' + parent.id + '.dijitCheckBox').forEach(function(node) {
if (i > 0) {
var isSet = dijit.getEnclosingWidget(node).get('checked');
console.log(isSet);
if (isSet == false) {
selected = false;
}
}
i++;
});
if (selected) {
parent.checkBox.set('checked', true);
}
}
}
//console.log(node.id);
},
_createTreeNode: function(args) {
var tnode = new dijit._TreeNode(args);
tnode.labelNode.innerHTML = args.label;
console.log(args);
var cb = new dijit.form.CheckBox({
"aria-checked": "false",
"aria-describedby": args.label
});
cb.placeAt(tnode.labelNode, "first");
tnode.checkBox = cb;
return tnode;
}
});
tree.placeAt(contentHere);
tree.startup();
tree.checkedItems();
//tree.expandAll();
});
}
Alle Ideen, wie man es per Tastatur zugänglich?
Danke!
Genau das, was ich brauchte! Ich danke dir sehr. – pdabade
Können Sie bitte einen Link zur Dijit/Baumquelle geben? – pdabade
https://github.com/dojo/dijit/blob/master/Tree.js Sie können die vollständigen Quellen auch von http://download.dojotoolkit.org/ herunterladen. – pgianna