javascript uuid技术
这主要用于选择器过滤重复元素时用的。
涉及三种可能的手段:sourceIndex,uniqueID与自定义的uuid。
sourceIndex 获取元素节点在页面的出现顺序,即为其在document.all集合中的索引号。由于要准确获取先后位置,如果在其前面插入一个元素节点,那么它的位置就要加一。换言之,它是动态分配的,每次都要重复计算。注意,IE only,只读。
uniqueID 也是一个IE only的只读属性。这个属性也不是早早就固化在元素节点中,只在我们第一次访问它时才开始为整个页面分配uniqueID。这意味着,如果我们用它来做选择器的过滤,第一次可能会很慢。另,document对象也具有这个属性,不过它和其它HTML的uniqueID属性的意义是完全不同的。当我们每调用一次document.uniqueID,系统就会返回一个新的uniqueID值。
window.onload = function(){
alert(document.uniqueID)//注意:IE only
alert(document.uniqueID)
alert(document.uniqueID)
}
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta content="IE=8" http-equiv="X-UA-Compatible"/>
<title>uuid by 司徒正美 </title>
<script type="text/javascript">
window.onload = function(){
alert(document.uniqueID)
alert(document.uniqueID)
alert(document.uniqueID)
}
</script>
</head>
<body>
</body>
</html>
运行代码
这两个东西都是IE ony,而且只能用于HTMLDocument,因此我们注定要自行设计一个通行的方案。看jQuery是怎样实现的:
var expando = "jQuery" + now(), uuid = 0,
//*****************略*******************
var id = elem[ expando ]
不过在IE下,有些元素在添加自定义属性时会出错,如object,applet,embed。这比较作孽。
相关文档:
引用
Aaron 的 javascript定义对象写法(整理)
javascript定义对象的几种简单方法
1.构造函数方式,全部属性及对象的方法都放在构造方法里面定义
优点:动态的传递参数
缺点:每创建一个对象就会创建相同的方法函数对象,占用大量内存
function User1(name, password) {
this.name = name;
this.password = pass ......
Javascript代码收藏大全
1. oncontextmenu="window.event.returnvalue=false" 将彻底屏蔽鼠标右键
<table border oncontextmenu=return(false)><td>no</table> 可用于Table
2. <body onselectstart="return false"> 取消选取、防止复制
3. onpaste="return false" 不准粘贴
4. oncopy="retu ......
事件源对象
event.srcElement.tagName
event.srcElement.type
捕获释放
event.srcElement.setCapture();
event.srcElement.releaseCapture();
事件按键
event.keyCode
event.shiftKey
event.altKey
event.ctrlKey
事件返回值
event.returnValue
鼠标位置
event.x
e ......
<!--
@page { margin: 2cm }
P { margin-bottom: 0.21cm }
A:link { so-language: zxx }
-->
面向对象基础
JavaScript
是完全面向对象的语言。所以不可能以非面向对象的方法来使用。
对象(
Object
)
从最基本的层次上说,对象是一系列属性的集合,和其他语言里的散列表结构类似。
例如:两个 ......