用圖片做爲label,for屬性IE下不起做用

    IE瀏覽器存在一個BUG,當你使用label的for屬性達到點擊label使對應的表單元素聚焦,label中的內容爲圖片時,IE瀏覽器下不起做用html

例如:
瀏覽器

<input type="checkbox" id="a"><label for="a"><img src="..."></label>


咱們但願獲得的效果是:點擊「中國銀行」,複選框會被選上(或者取消)。在FireFox,CHROME等瀏覽器下是沒有問題的,可是IE瀏覽器卻不吃這套。

解決的辦法是使用JS:
app

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; 
                    } 
                } 
            } 
        }
    }
}

*此代碼須要先加載html文檔,實際目的是從新綁定label的點擊事件。ide

相關文章
相關標籤/搜索