我已经看到了这个问题,并且我已经尝试了给出的解决方案(使用 tree.reload()),但它对我不起作用。我有一个树,它使用 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(),我尝试在调用 reload( ),我被困住了。
有任何想法吗?
此时,我决定唯一要做的就是将树初始化放入一个函数中,并在更改选择选项时,将树(包括其父 div)吹走并重建它。如果真的没有其他方法可以用新数据重建树,我会感到惊讶,这与我使用其他小部件的经验背道而驰。