用圖片作為label,for屬性IE下不起作用

字號(hào):


    IE瀏覽器存在一個(gè)BUG,當(dāng)你使用label的for屬性達(dá)到點(diǎn)擊label使對(duì)應(yīng)的表單元素聚焦,label中的內(nèi)容為圖片時(shí),IE瀏覽器下不起作用。
    例如:
    代碼如下:
    <input type="checkbox" id="a"><label for="a"><img src="..."></label>
    我們希望得到的效果是:點(diǎn)擊“中國(guó)銀行”,復(fù)選框會(huì)被選上(或者取消)。在FireFox,CHROME等瀏覽器下是沒(méi)有問(wèn)題的,但是IE瀏覽器卻不吃這套。
    解決的辦法是使用JS:
    代碼如下:
    window.onload = function(){
    if(document.all && navigator.appVersion.indexOf("MSIE")>-1 && navigator.appVersion.indexOf("Windows")>-1)
    {
    var a = document.getElementsByTagName("label");
    for(var i=0,j=a.length;i<j;i++){
    if(a[i].hasChildNodes && a[i].childNodes.item(0).tagName == "IMG")
    {
    a[i].childNodes.item(0).forid = a[i].htmlFor;
    a[i].childNodes.item(0).onclick = function(){
    var e = document.getElementById(this.forid);
    switch(e.type){
    case "radio": e.checked|=1;break;
    case "checkbox": e.checked=!e.checked;break;
    case "text": case "password": case "textarea": e.focus(); break;
    }
    }
    }
    }
    }
    }