当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > 找到html标记对应的脚本属性

CSS样式表
web标准常见问题集合4
web标准常见问题集合5
我的一些关于web标准的思考笔记(一)
关于filter滤镜应用于图片的两种创意
Div+Css(+Js)菜单代码及制作工具
css写菜单:简洁注释版
标准布局应用:显示/隐藏侧边栏 [附详细注解]
小心:CSS代码书写顺序不同,导致显示效果不一样
解决鼠标在 flash 链接上不停闪动的问题(web页面中)
从gb到utf-8
html在线编辑器的更新[2006-05]
对hao123进行重构
韩国商业网站设计分析
模仿combox(select)控件,不用为美化select烦恼了。
【已解决】标签页刷新问题
以前写的两个CSS树形菜单
CSS样式表的背景渲染效率
第1天:选择什么样的DOCTYPE
第2天:什么是名字空间
第3天:定义语言编码

CSS样式表 中的 找到html标记对应的脚本属性


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-12   浏览: 60 ::
收藏到网摘: n/a

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的脚本属性上,大家不妨试试。