获取网页元素
document.getElementsByName("title");
document.getElementsByTagName("title");
document.getElementsByClassName("title");
利用来JS控制页面控件显示和隐藏有两种方法,两种方法分别利用HTML的style中的两个属性,两种方法的不同之处在于控件隐藏后是否还在页面上占空位。
方法一:
document.getElementById("EleId").style.visibility="hidden";
document.getElementById("EleId").style.visibility="visible";
利用上述方法实现隐藏后,页面的位置还被控件占用,显示空白。
方法二:
document.getElementById("EleId").style.display="none";
document.getElementById("EleId").style.display="inline";
利用上述方法实现隐藏后,页面的位置不被占用。
如果是 ByClassNam 或者 ByTagName ,例如
document.getElementsByClassName("title").style.display="none"
会报错:Uncaught TypeError: Cannot set property 'display' of undefined
因为得到的是一个由class="xxx"的所有元素组成的集合,而不是单个元素;集合是没有display属性的,集合中的元素才有display属性。当你试图做 集合.style.display的时候,自然会报错。
正确方法是加上一个下标,
document.getElementsByClassName("title")[0].style.display='none'
或者遍历让集合所有的元素生效
var x=document.getElementsByClassName("title");
for (var i = 0; i<x.length;i++) {
x[i].style.display="none";
};