zoukankan      html  css  js  c++  java
  • 用图片作为label,for属性IE下不起作用

      IE浏览器存在一个BUG,当你使用label的for属性达到点击label使对应的表单元素聚焦,label中的内容为图片时,IE浏览器下不起作用。

    例如: 

    <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; 
    } 
    } 
    } 
    } 
    } 
    } 
  • 相关阅读:
    Vue props向子组件中传递数据
    Vue 组件间的通信
    vue slot插槽
    Vue 组件化注意事项
    VUE多个组件示例
    Vue组件化开发
    Vue 获取当前时间并格式化
    VUE 过滤器以及插件
    Vue 表单数据双向绑定 v-mode
    VUE 事件修饰符以及按键码
  • 原文地址:https://www.cnblogs.com/dongtianqi/p/7458230.html
Copyright © 2011-2022 走看看