У меня есть простой HTML-макет, который выглядит следующим образом:
<div id="foo">
<ul>
<li id="id1"><a href="#">some category 1</a>
<ul><li><a href="#">some text</a></li></ul>
<ul><li><a href="#">some text</a></li></ul>
</li>
<li id="id2"><a href="#">some category 2</a>
<ul><li><a href="#">some text</a></li></ul>
<ul><li><a href="#">some text</a></li></ul>
</li>
</ul>
</div>
Определение Jstree выглядит следующим образом
$('#foo').jstree({
"core" : {
"animation" : 0
},
"themes" : {
"theme" : "classic",
"dots" : false,
"icons" : true
},
"sort" : function (a, b) {
return this.get_text(a) > this.get_text(b) ? 1 : -1;
},
"types" : {
"valid_children" : [ "folder" ],
"types" : {
"folder" : {
"valid_children" : [ "file" ],
"icon" : { "image" : "/path/to/images/folder.png"},
"max_depth" : 1
},
"file" : {
"valid_children" : [ "none" ],
"icon" : { "image" : "/path/to/images/file.png" },
}
}
},
"plugins" : [ "html_data", "themes", "contextmenu", "search", "sort", "types" ]
});
Однако я все еще получаю общие значки тем для файлов.
Категория должна иметь папку, а подкатегории должны иметь файл. Я что-то упустил?
Вот ответ. Для каждого типа, «папка», «файл» и т. Д. Вы помещаете в элемент списка rel = где что-то есть «папка» и еще много чего. Затем в вашей конфигурации jstree у вас есть следующие настройки для плагина типов:
'types' : {
'valid_children' : [ 'folder' ],
'types' : {
'folder' : {
'valid_children' : [ 'file'],
'max_depth' : 1
},
'file' : {
'valid_children' : [ 'none' ],
'icon' : { 'image' : safari.extension.baseURI + 'images/file.png' },
}
}
},
Здесь мы определяем, что делать с каждым типом "rel". Таким образом, jstree выберет тип rel в элементе списка и выяснит, что с ним делать из этих определений.