国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > CSS > 正文

解決CSS中 display 與 visibility 的區別

2020-10-23 18:43:20
字體:
來源:轉載
供稿:網友
大多數人很容易將CSS屬性display和visibility混淆,它們看似沒有什么不同,其實它們的差別卻是很大的。
visibility屬性用來確定元素是顯示還是隱藏的,這用visibility="visible|hidden"來表示(visible表示顯示,hidden表示隱藏)。
當visibility被設置為"hidden"的時候,元素雖然被隱藏了,但它仍然占據它原來所在的位置。例:

[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執行]

注意到,當元素被隱藏之后,就不能再接收到其它事件了,所以在第一段代碼中,當其被設為"hidden"的時候,就不能再接收響應到事件了,因此也就無法通過鼠標點擊第一段文本令其顯示出來。
另一方面,display屬性就有一點不同了。visibility屬性是隱藏元素但保持元素的浮動位置,而display實際上是設置元素的浮動特征。
當display被設置為block(塊)時,容器中所有的元素將會被當作一個單獨的塊,就像<div>元素一樣,它會在那個點被放入到頁面中。(實際上你可以設置<span>的display:block,使其可以像<div>一樣工作。
將display設置為inline,將使其行為和元素inline一樣---即使它是普通的塊元素如<div>,它也將會被組合成像<span>那樣的輸出流。
下面看我實例的代碼和效果:

[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執行]

最后是display被設置:none,這時元素實際上就從頁面中被移走,它下面所在的元素就會被自動跟上填。(此時應用display: none;的元素相當于消失,而visibility: hidden;則只表示隱藏,位置還在。)
display 屬性分別為block, inline, none 值及使用visibility: hidden;的情況調試示例:

[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執行]

同時,關于display:inline;和float:left;兩者的區別可以參看該篇文章:
(display是指顯示狀態,inline表示內聯,特點是緊貼著前一個內聯元素,通常默認的內聯元素有span,a,em,strong等。而float表示的是浮動,float:left,是針對塊級元素的浮動形式,是不同形式的兩種狀態。)
http://www.andymao.com/andy/post/42.html
http://bbs.blueidea.com/thread-2596793-1-1.html

[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執行]

解決:
查CSS手冊后發現了隱藏內容原來是有區別的,一種是保留對象的物理空間,一種是不保留。
-------------------------------
display:none
CSS1  隱藏對象。與 visibility 屬性的hidden值不同,其不為被隱藏的對象保留其物理空間 

visibility:hidden
對象隱藏,與 display 屬性不同,此屬性為隱藏的對象保留其占據的物理空間。

但是因為使用了visibility:hidden,拉長的內容其實就是那個含有圖片的DIV;而改用display:none后就正常了。剛剛還一直懷疑是高度設置的問題,沒想到居然就是這么簡單的一點內容,結果用了這么多的時間跟精力,唉…… 
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 红河县| 玉龙| 南阳市| 新竹县| 呼和浩特市| 琼结县| 绍兴市| 澄城县| 牡丹江市| 新乐市| 旬阳县| 察雅县| 且末县| 泾源县| 沙坪坝区| 财经| 明光市| 乡宁县| 大连市| 盐池县| 萝北县| 永和县| 新绛县| 沙坪坝区| 台湾省| 烟台市| 高台县| 高尔夫| 澳门| 建平县| 聂荣县| 通山县| 浪卡子县| 吉木乃县| 深州市| 兴国县| 清水县| 泾源县| 泾源县| 绥德县| 彭山县|