用圖片作為label,for屬性IE下不起作用
摘要:IE瀏覽器存在一個BUG,當你使用label的for屬性達到點選label使對應的表單元素聚焦,label中的內容為圖片時,IE瀏覽器下不起作用。
例如:
解決的辦法是使用JS:
<input type="checkbox" id="a"><label for="a"><img src="..."></label>我們希望得到的效果是:點選「中國銀行」,復選框會被選上(或者取消)。在FireFox,CHROME等瀏覽器下是沒有問題的,但是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; } } } } } }
網站選單
Search
好站推薦
美人時計