js 查找页面重复元素
2015-01-22 15:03
246 查看
<body>
<form id="form1" runat="server">
<div id="Div1"></div>
<div id="Div2"></div>
<div id="Div3"></div>
<div id="Div4"></div>
<div id="Div5"></div>
<div id="Div3">这是重复的DIV元素</div>
</form>
</body>
找出html中重复id的元素。如果是我来解答那应该就是先得到所有的元素document.getElementsByTagName("*"),然后一个一个去匹配数组中有没有重复的,这样应该是两个for循环。- _-|||
现在摘录网上比较牛B的解法。
方法一:巧用document.getElementById
document.getElementById根据id获取DOM对象时,如果有多个同名id,获取的是第一个该id的DOM对象,获取所有标签后,逆序遍历判断该DOM元素o与document.getElementById(o.id)是不是同一个DOM元素,是就继续,不是就说明id重复了。
代码
var tags = document.getElementsByTagName("*");
for (var i = tags.length - 1; i > -1; i--) {
var o = tags[i];
var id = o.id;
//如果该元素不等于document.getElementById出来的那个就说明重复了
if (id && document.getElementById(id) != o) {
alert(id + "重复了");
break;
}
}
if (i == -1) { alert("没有出现相同的id") }
总结:document.getElementById这么简单的东西也有额外的知识点存在^_^
方法二:运用字典的方式
先new出一个字典对象,然后将页面上所有的元素id当成key放进字典对象中,循环的时候如果在字典对象中已经存在了就说明重复了
var el = document.getElementsByTagName("*");
//创建字典对象
var d = new ActiveXObject("Scripting.Dictionary");
//循环每一个节点
for (var i = 0; i < el.length; i++) {
if (el[i].id != "") {
//字典中是否已经存在
if (d.Exists(el[i].id)) {
return alert("有重复元素" + el[i].id)
}
else {
d.add(el[i].id, "")
}
}
}
总结:ActiveXObject对象可以研究一下,后面再来讨论。
方法三:利用对象中的hasOwnProperty方法
该方法与上面的利用字典差不多是一个意思,巧妙的运用了hasOwnProperty方法。
var el = document.getElementsByTagName("*");
//声明一个对象
var obj = {};
for (var i = 0; i < el.length; i++) {
if (el[i].id != "") {
//obj对象中是否已经有该属性
if (obj.hasOwnProperty(el[i].id)) {
return alert("有重复" + el[i].id)
}
//没有就给该对象添加这么一个属性,赋值为空
else {
obj[el[i].id] = '';
}
}
}
另外补充知识:
JavaScript中ActiveXObject对象是启用并返回 Automation 对象的引用。通过它可以访问windows的本地文件系统和应用程序,比如:有的时候我们需要得到用户的机器名,用户名,得到某个文件的信息,或者读写注册表,或者启动计算器、outlook等应用程序。
var WshNetwork = new ActiveXObject("WScript.Network");
var pnsys = new ActiveXObject("WScript.shell");
var fs = new ActiveXObject("scripting.filesystemobject"); //文件信息相关
new ActiveXObject("Scripting.Dictionary");//字典对象
它的集合中每一项包含两个属性一个是键值,一个是值,即(key,value),其中value可以是任何类型的对象或数值。
示例代码:
var obj = new ActiveXObject("Scripting.Dictionary"); //创建对象
obj.Add("hello", null); //增加新项
obj.Item("hello") = "Chiweiyao"; //给新增添的项赋值
obj.Add("world", null);
obj.Item("world") = "Greate";
var keys = obj.Keys().toArray(); //将obj对象的键值转换成数组
for (var i = 0; i < keys.length; i++) {
if (obj.Exists(keys[i])) {//判断对象集合中是否存在指定键值的项
obj.Item(keys[i]) = null;
obj.Remove(keys[i]); //删除指定键值项
}
}
最常用的貌似是AJAX中的ActiveXObject("Microsoft.XMLHTTP");
最杯具的是ActiveXObject只有IE支持,如果要FF支持有两个方法:
1、使用IETab插件,在Firefox下调用IE浏览器内核
2、使用npActivexPlugin插件
<form id="form1" runat="server">
<div id="Div1"></div>
<div id="Div2"></div>
<div id="Div3"></div>
<div id="Div4"></div>
<div id="Div5"></div>
<div id="Div3">这是重复的DIV元素</div>
</form>
</body>
找出html中重复id的元素。如果是我来解答那应该就是先得到所有的元素document.getElementsByTagName("*"),然后一个一个去匹配数组中有没有重复的,这样应该是两个for循环。- _-|||
现在摘录网上比较牛B的解法。
方法一:巧用document.getElementById
document.getElementById根据id获取DOM对象时,如果有多个同名id,获取的是第一个该id的DOM对象,获取所有标签后,逆序遍历判断该DOM元素o与document.getElementById(o.id)是不是同一个DOM元素,是就继续,不是就说明id重复了。
代码
var tags = document.getElementsByTagName("*");
for (var i = tags.length - 1; i > -1; i--) {
var o = tags[i];
var id = o.id;
//如果该元素不等于document.getElementById出来的那个就说明重复了
if (id && document.getElementById(id) != o) {
alert(id + "重复了");
break;
}
}
if (i == -1) { alert("没有出现相同的id") }
总结:document.getElementById这么简单的东西也有额外的知识点存在^_^
方法二:运用字典的方式
先new出一个字典对象,然后将页面上所有的元素id当成key放进字典对象中,循环的时候如果在字典对象中已经存在了就说明重复了
var el = document.getElementsByTagName("*");
//创建字典对象
var d = new ActiveXObject("Scripting.Dictionary");
//循环每一个节点
for (var i = 0; i < el.length; i++) {
if (el[i].id != "") {
//字典中是否已经存在
if (d.Exists(el[i].id)) {
return alert("有重复元素" + el[i].id)
}
else {
d.add(el[i].id, "")
}
}
}
总结:ActiveXObject对象可以研究一下,后面再来讨论。
方法三:利用对象中的hasOwnProperty方法
该方法与上面的利用字典差不多是一个意思,巧妙的运用了hasOwnProperty方法。
var el = document.getElementsByTagName("*");
//声明一个对象
var obj = {};
for (var i = 0; i < el.length; i++) {
if (el[i].id != "") {
//obj对象中是否已经有该属性
if (obj.hasOwnProperty(el[i].id)) {
return alert("有重复" + el[i].id)
}
//没有就给该对象添加这么一个属性,赋值为空
else {
obj[el[i].id] = '';
}
}
}
另外补充知识:
JavaScript中ActiveXObject对象是启用并返回 Automation 对象的引用。通过它可以访问windows的本地文件系统和应用程序,比如:有的时候我们需要得到用户的机器名,用户名,得到某个文件的信息,或者读写注册表,或者启动计算器、outlook等应用程序。
var WshNetwork = new ActiveXObject("WScript.Network");
var pnsys = new ActiveXObject("WScript.shell");
var fs = new ActiveXObject("scripting.filesystemobject"); //文件信息相关
new ActiveXObject("Scripting.Dictionary");//字典对象
它的集合中每一项包含两个属性一个是键值,一个是值,即(key,value),其中value可以是任何类型的对象或数值。
示例代码:
var obj = new ActiveXObject("Scripting.Dictionary"); //创建对象
obj.Add("hello", null); //增加新项
obj.Item("hello") = "Chiweiyao"; //给新增添的项赋值
obj.Add("world", null);
obj.Item("world") = "Greate";
var keys = obj.Keys().toArray(); //将obj对象的键值转换成数组
for (var i = 0; i < keys.length; i++) {
if (obj.Exists(keys[i])) {//判断对象集合中是否存在指定键值的项
obj.Item(keys[i]) = null;
obj.Remove(keys[i]); //删除指定键值项
}
}
最常用的貌似是AJAX中的ActiveXObject("Microsoft.XMLHTTP");
最杯具的是ActiveXObject只有IE支持,如果要FF支持有两个方法:
1、使用IETab插件,在Firefox下调用IE浏览器内核
2、使用npActivexPlugin插件
相关文章推荐
- js 查找数组重复元素方法
- JS查找数组中重复元素的方法详解
- JS 之 查找数组中重复的元素
- js:查找重复元素
- JS编程训练 | 题11:查找重复元素
- 时间复杂度为o(N)查找1至N-1构成的a[N]重复元素
- 查找DOM元素的方法集合(searchElement.js)
- js动态取页面元素位置的方法
- JS获得页面某一元素的位置
- 用JS取得页面上所有元素的值
- 如何使用js减少页面大量重复(js事件)语句
- C/C++面试之算法系列--时间复杂度为o(N)查找1至N-1构成的a[N]重复元素
- js获取页面元素位置函数
- js获得页面元素位置
- js获取页面元素位置函数(浏览器兼容)
- [CSS+JS]同一页面可以重复使用的选项卡收藏
- js获取页面元素位置函数
- 实现页面元素拖放功能的JS
- js根据属性查找元素代码
- [转]JS页面内查找