display:none|block;
display:none;
隐藏该html元素,确切的说,是在浏览器中消除该元素,不占屏幕的空间。若其下有其他元素,就会上移到该空间区域(好像桌子上有100块钱,现在我把它放在抽屉里藏起来,桌子上放100钱的地方可以放在其他任何东西)。
dispaly:block;
显示已经隐藏的html元素,如果别的元素占有了该空间时,他将下移,空间重新别原来的元素占有。(把100块钱重新从抽屉里那出来放回桌子上)。
visibility:hidden|visible;
visibility:hidden;
隐藏该元素,正真的隐藏,但他还占有那块空间。这时,(桌子上有100块钱,这是我盖了桌布把他隐藏起来,钱还在那里)。
visibility:visible;
让元素显示(拿掉了桌布,看到了100块钱)。
所以display和visibility控制的分别是html元素是否存在和是否显示,display的属性定义该元素存在或不存在,而visibility的属性只是控制该元素是否显示出来,实际上还是存在的。
接下来用代码来举个例子,代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
<
html
>
<
head
>
<
script
type
=
"text/javascript"
>
function testDisplay()
{
var divD = document.getElementById("testD");
if(divD.style.display=="none")
{
divD.style.display = "block";
}
else
{
divD.style.display = "none";
}
}
function testVisibility()
{
var divV = document.getElementById("testV");
if(divV.style.visibility =="hidden")
{
divV.style.visibility ="visible";
}
else
{
divV.style.visibility = "hidden";
}
}
</
script
>
</
head
>
</
body
>
<
div
id
=
"testD"
style
=
"border:#ddd 1px solid"
>
<
div
style
=
"display:block;border:#ccc 2px solid"
>
<
div
style
=
"visibility:visible;border:#aaa 2px solid"
>
Display
</
div
>
</
div
>
</
div
>
<
div
id
=
"testV"
style
=
"border:#ddd 1px solid"
>
<
div
style
=
"display:block;border:#ccc 2px solid"
>
<
div
style
=
"visibility:visible;border:#aaa 2px solid"
>
Visibility
</
div
>
</
div
>
</
div
>
<
input
type
=
"button"
value
=
"TestDisplay"
onclick
=
"testDisplay()"
/>
<
input
type
=
"button"
value
=
"TestVisibility"
onclick
=
"testVisibility()"
/>
</
body
>
</
html
>
|