我正在尝试制作一个dojo Code工作并且有点困难。 背后的意图是这样的:
1-选择一个onChange事件,通过dojo.xhrGet检索选项列表。 2-检索到的每个选项都有自己的关联/绑定的onclick事件,它触发的函数需要2个参数
问题:此时,选项上的onClick事件一旦通过Ajax检索就会触发,并且不会传递firt参数。事件之后事件停止(点击不产生任何结果)。
感谢您提前的反馈。该守则如下
JS
function checkAvailable(i){
var id_prog = 'programa_'+i;
var id_coreo = 'coreografia_'+i;
var prog = dojo.byId(id_prog).value;
dojo.xhrGet({
url:"ajaxCoreo.php",
handleAs:"text",
content: {
programa: prog,
item: i
},
load: function(data){
var targetNode = dojo.byId(id_coreo);
dojo.place(data,targetNode,"only");
dojo.byId(id_coreo).disabled = false;
var callback = function(evt){
var j = evt.target.innerHTML;
checkPack(j,i);
console.log('write me if you fire inside first function');
};
dojo.query("#coreografia_1>option").connect('click', callback);
setValor(i);
}
});
}
function checkPack(j,i){
console.log('write me if you fire inside second function');
console.log(j);
console.log(i);
var num = j;
var id_prog = 'programa_'+i;
var id_coreo = 'coreografia_'+j;
var prog = dojo.byId(id_prog).value;
dojo.xhrGet({
url:"ajaxPack.php",
handleAs:"text",
content: {
programa: prog,
coreo: j
},
load: function(data){
if(data=="true"){
dojo.query("option[value="+num+"]").forEach(dojo.destroy);
alert('O Pack escolhido já foi encomendado previamente.');
setValor(i);
}
}
});
}
HTML
<select name="programa[]" id="programa_1" onChange="checkAvailable(1)" title="obrigatorio">
<option value="0">Choose your program</option>
</select>
<select name="coreografia_1" id="coreografia_1" disabled="disabled" title="obrigatorio">
<option value="0" selected="selected">Escolha Um Programa</option> //this is the node that is populated by the first xhrGet call
</select>
编辑:我编辑了代码以反映对它的更改并添加了html
答案 0 :(得分:0)
通过检查您的代码,我可以在函数 checkAvailable 中看到您连接到 onclick 事件的行,而不是将该函数作为回调传递你正在调用它。
dojo.connect(opt,'onclick', checkPack(opt.target.innerHTML,i));
你应该这样做:
var callback = function(){
checkPack(opt.target.innerHTML,i);
};
dojo.connect(opt,'onclick', callback);
答案 1 :(得分:0)
根据我的经验,如果您花费超过1天的时间尝试跟踪跨行业问题,那么它可能会基于您的基本HTML知识或基本的Js概念。
这与只有FF管理直接附加到选项标签的onclick事件有关。对于其他人,你需要将onchange附加到父母身上。
所以这是工作代码的最终版本,以防任何人遇到类似的问题
function checkAvailable(i){
var id_prog = 'programa_'+i;
var id_coreo = 'coreografia_'+i;
var prog = dojo.byId(id_prog).value;
dojo.xhrGet({
url:"ajaxCoreo.php",
handleAs:"text",
content: {
programa: prog,
item: i
},
load: function(data){
var targetNode = dojo.byId(id_coreo);
dojo.place(data,targetNode,"only");
dojo.byId(id_coreo).disabled = false;
var callback = function(evt){
var j = evt.target.value;
checkPack(j,i);
};
dojo.query("#coreografia_"+i).connect('onchange', callback);
setValor(i);
}
});
}
function checkPack(j,i){
console.log('write me if you fire inside second function');
console.log(j);
console.log(i);
var num = j;
var id_prog = 'programa_'+i;
var id_coreo = 'coreografia_'+j;
var prog = dojo.byId(id_prog).value;
//Confirma Se não há encomendas previas deste pack (um máximo de 2 anteriores)
dojo.xhrGet({
url:"ajaxPack.php",
handleAs:"text",
content: {
programa: prog,
coreo: j
},
load: function(data){
if(data=="true"){
dojo.query("#coreografia_"+i+" option[value="+num+"]").forEach(dojo.destroy);
alert('O Pack escolhido já foi encomendado previamente.');
}
}
});
}