Mootools 1.2.4代表团不在IE8工作......?

时间:2010-05-02 19:35:36

标签: internet-explorer-8 events mootools delegation

所以我在表单旁边有一个列表框。当用户单击选择框中的选项时,我会在JSON对象中返回相关数据的请求,该对象将被放入表单元素中。保存表单后,请求将通过,并使用更新的数据重建列表框。由于它正在重建,我正在尝试在列表框的父div上使用委托来进行onchange代码。我遇到的麻烦是IE8(大震惊)没有解雇委托事件。

我有以下HTML:

<div id="listwrapper" class="span-10 append-1 last">  
<select id="list" name="list" size="20">  
     <option value="86">Adrian Franklin</option>  
     <option value="16">Adrian McCorvey</option>  
     <option value="196">Virginia Thomas</option>  
</select>  
</div>  

以及下面的脚本:

window.addEvent('domready', function() {     
  var jsonreq = new Request.JSON();  

  $('listwrapper').addEvent('change:relay(select)', function(e) {  
    alert('this doesn't fire in IE8');  
    e.stop();  
    var status= $('statuswrapper').empty().addClass('ajax-loading');  
    jsonreq.options.url = 'de_getformdata.php';  
    jsonreq.options.method = 'post';  
    jsonreq.options.data = {'getlist':'<?php echo $getlist ?>','pkey':$('list').value};  
    jsonreq.onSuccess = function(rObj, rTxt) {  
        status.removeClass('ajax-loading');  
        for (key in rObj) {  
              status.set('html','You are currently editing '+rObj['cname']);  
              if ($chk($(key))) $(key).value = rObj[key];  
        }  
        $('lalsoaccomp-yes').set('checked',(($('naccompkey').value > 0)?'true':'false'));  
        $('lalsoaccomp-no').set('checked',(($('naccompkey').value > 0)?'false':'true'));  
    }  
    jsonreq.send();  
  });  
});  

(我拿出了一些不相关的东西)。所以这一切都在firefox中按预期工作,但是IE8拒绝在select元素上触发委托的更改事件。如果我将更改功能直接附加到选择,那么它可以正常工作。

我错过了什么吗? IE8是否不喜欢:relay?

旁注:我对mootools和javascripting等都很陌生,所以如果有一些可以改进代码的东西,请告诉我。 谢谢!

1 个答案:

答案 0 :(得分:0)

元素委派不适用于IE中的字段元素(input / select / textarea)。