原生JS通过id和class获取元素是用,document.getElementById(IDname),document.getElementsByClassName('ClassName');
兼容性:ID兼容,class 不兼容IE6,7,8
数量: 通过ID只能获取一个dom元素,通过class可以获取一组元素。
通用性:ID不能重复,class可以重复,所以class比较好用,这也是jQuery能被广泛应该的原因(选择器好)。
获取元素还是class来得快,用id,如果是你说的上千个文档,那是不现实的。
滚动也不难。
1 如果是id,可以直接用js取出来id,然后使用
window.location = window.location+'#获取到的ID'
这样滚动到锚点。
2 如果是class,那就用
var l = document.getElementsByClassName('类名称');
for(var i=0;i
l[i].setAttribute('id', 'mark'+i);
}
}
也就是先获取到所有的class元素,再给没有id属性的元素添加一个id,最后执行1的操作就可以了。
这要用到框架了 prototype就有这样的方法 getElementsByClassName()