Попытка перезагрузить / обновить dynatree новыми данными
Я уже видел этот вопрос, и я попробовал данное решение (используйте tree.reload()), но оно не работает для меня. У меня есть дерево, которое инициализируется в doc ready с использованием initAjax(), и я пытаюсь перезагрузить дерево, используя другие значения, при изменении выбора ввода. В основном это:
$(document).ready(function(){
// global variables
var myVal = 'initial value';
// initialize tree
$('#tree').dynatree({
persist: false,
initAjax: {
url: 'getMyStuff.cfc',
data: { myParam: myVal }
},
... more params
)};
// select change handler
$('#mySelect).change(function(){
var tree = $('#tree').dynatree('getTree');
myVal = $(this).find('option:selected').val();
tree.reload();
)};
)};
Проблема в том, что дерево продолжает перезагружаться с теми же параметрами... Я вижу на вкладке сети консоли, что отправляемый параметр всегда один и тот же, даже если я убедился, что нацеливаюсь на правильный элемент и получаю правильное значение при изменении.
Я попытался изменить область видимости переменных, я попытался поместить параметры dynatree в отдельную переменную, я попытался вызвать
$('#tree').children().remove();
$('#tree').dynatree(treeoptions);
внутри функции change() я попытался вызвать tree.initialize() (да, я знаю, что это конструктор), я попробовал tree.redraw(), я пытался установить опцию initAjax отдельно перед вызовом reload () и я застрял.
Есть идеи?
На данный момент я решил, что единственное, что нужно сделать, это поместить инициализацию дерева в функцию, а при изменении опции выбора сдуть дерево (включая его родительский div) и перестроить его. Я буду удивлен, если это правда, что нет другого способа перестроить дерево с новыми данными, что противоречит моему опыту работы с другими виджетами.
3 ответа
Этот вопрос является дубликатом этого: как перезагрузить / обновить / переустановить DynaTree?
Мое решение не требует обходных путей, таких как empty(), destroy() и т. Д. Подумайте об этом: когда создается Dynatree, вы указываете словарь настроек, которые он должен использовать. Однако, поскольку это словарь конфигурации, он не будет переоцениваться, даже если некоторые параметры являются переменными и изменяются в результате щелчков и т. Д. Поэтому, чтобы решить эту проблему и избежать дорогостоящих операций, таких как удаление DOM и повторное его создание, мы делаем это так, как я думаю разработчики Dynatree имеет это намерение (но не так четко задокументировано в примере AJAX/JSON):
//The HTML:
<input name="filter" id="checkbox" type="checkbox" value="X">Checkme<br>
<label id="mylabel"></label>
$("#checkbox").click(function() {
$("#mylabel").text($(this).is(":checked"))
$("#tree").dynatree("option", "initAjax", {
url: "myurl/myphp.php",
data: {
myparameter: $("#checkbox").is(":checked").toString()
}
});
$("#tree").dynatree("getTree").reload();
});
Этот пример устанавливает конфигурацию на #tree каждый раз, когда нажимается кнопка, а затем перезагружает дерево.
Я нашел это в гугл-группе dynatree. Меня устраивает.
$('.tree').dynatree('destroy');
$('.tree').empty();
Вот оригинальная ссылка.
Я хотел инициализировать блок с помощью json по умолчанию, а затем по нажатию кнопки я хотел обновить его с сервера. Это то, что я сделал. По сути, var treeData = [{title: "Dynamic Tree Demo",isFolder: false, tooltip: "Вот ваше Динамическое Дерево!" }];
jQuery(document).ready(function() {
initReqActions(treeData);
});
initReqActions= function(myTree){
$("#dynaTree").dynatree({
checkbox: false,
selectMode: 2,
// create IDs for HTML elements that are generated
generateIds: true,
cookie: {
expires :-1
},
children: myTree,
onQuerySelect: function(select, node) {
if( node.data.isFolder )
return false;
},
onSelect: function(select, node) {
// Display list of selected nodes
var selNodes = node.tree.getSelectedNodes();
// convert to title/key array
//var selKeys = $.map(selNodes, function(node){
// return "[" + node.data.key + "]: '" + node.data.title + "'";
//});
//$("#echoSelection4").text(selKeys.join(", "));
},
onClick: function(node, event) {
if( ! node.data.isFolder )
node.toggleSelect();
},
onDblClick: function(node, event) {
node.toggleExpand();
},
onKeydown: function(node, event) {
if( event.which == 32 ) {
node.toggleSelect();
return false;
}
}
});
}
Затем, когда кнопка нажата
jQuery(document).ready(function() {
$("#RefreshButton").click(function() {
$("#dynaTree").dynatree("option", "initAjax", {
url: "refreshTree",
dataType: "json"
});
$("#dynaTree").dynatree("option", "children", null);
$("#dynaTree").dynatree("getTree").reload();
});
});