javascript中可以创建以及引用一个元素,进而通过这个元素来取得或者设置属性。然而一个元素的属性却不是和脚本中使用的属性一一对应的。一个较偏僻的属性,甚至google也很难找到其对应的脚本属性。今天我就遇到了这个问题:我需要创建一个label标记来对应一个复选框,使得点击这个label标记也能选中复选框。这是很常用的技术,比如如下的代码:

<input type="checkBox" id="cbTop"/>
<label for="cbTop">置顶</label>
就能够使得点击“置顶”两个字时也能选中复选框。
在正常情况下,这段代码是直接写到文件里的,很容易完成。当是我需要通过脚本创建,就遇到了问题,一般脚本属性和标记中写的属性是一样的,如链接标记a的目标属性href就保持一致。但因为for是javascript中的保留字,不能作为属性。我在网上找了很久也没找到for对应的脚本属性是什么,于是就酝酿出下面的办法来找到一个标记属性对应的脚本属性,现在就以找label的for属性对应的脚本属性为例: 
<label for="abcd" id="lblTest">test</label>
<script type="text/javascript">
 var lbl=document.getElementById("lblTest");
 for(var p in lbl){
  var s=eval("lbl."+p);
  if(s=="abcd")alert(p);
 }
</script>
原理是这样,我先写一个html标记到文档中,然后给要找的属性赋一个唯一值,例子中是给label的for属性复制"abcd",然后通过javascript引用这个元素,并且遍历它的所有属性,如果一个属性的值等于abcd,那么就可以认为这个属性的名称就是其对应的脚本属性。就是通过这个方法,发现了label的for属性对应的脚本属性应该是:htmlFor。嘿嘿,还是比较怪异的哦。类似的方法还可以应用在找css的脚本属性上,大家不妨试试。

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!

RTX 5090要首发 性能要翻倍!三星展示GDDR7显存

三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。

首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。

据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。