DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> CSS入門知識 >> 關於CSS >> 關於css 行元素和塊元素 相互轉換 居中
關於css 行元素和塊元素 相互轉換 居中
編輯:關於CSS     

一、塊級元素  行內元素

div、h1 或 p 元素常常被稱為塊級元素。這意味著這些元素顯示為一塊內容,即“塊框”。與之相反,span 和 strong 等元素稱為“行內元素”,這是因為它們的內容顯示在行中,即“行內框”。

您可以使用 display 屬性改變生成的框的類型。這意味著,通過將 display 屬性設置為 block,可以讓行內元素(比如 <a> 元素)表現得像塊級元素一樣。還可以通過把 display 設置為 none,讓生成的元素根本沒有框。這樣的話,該框及其所有內容就不再顯示,不占用文檔中的空間。

但是在一種情況下,即使沒有進行顯式定義,也會創建塊級元素。這種情況發生在把一些文本添加到一個塊級元素(比如 div)的開頭。即使沒有把這些文本定義為段落,它也會被當作段落對待:

 <div>                    顯示出來的效果為:               
some text                 some text
<p>Some more text.</p>    Some more text.
</div>

在這種情況下,這個框稱為無名塊框,因為它不與專門定義的元素相關聯。

塊級元素的文本行也會發生類似的情況。假設有一個包含三行文本的段落。每行文本形成一個無名框。無法直接對無名塊或行框應用樣式,因為沒有可以應用樣式的地方(注意,行框和行內框是兩個概念)。但是,這有助於理解在屏幕上看到的所有東西都形成某種框。

塊級元素特點:

1、每個塊級元素都從新的一行開始,並且其後的元素也另起一行。(真霸道,一個塊級元素獨占一行)

2、元素的高度、寬度、行高以及頂和底邊距都可設置。

3、元素寬度在不設置的情況下,是它本身父容器的100%(和父元素的寬度一致),除非設定一個寬度

塊狀元素也可以通過代碼display:inline將元素設置為內聯元素

內聯元素特點:

1、和其他元素都在一行上;

2、元素的高度、寬度及頂部和底部邊距不可設置;

3、元素的寬度就是它包含的文字或圖片的寬度,不可改變。

常用的塊狀元素有:

<div>、<p>、<h1>...<h6>、<ol>、<ul>、<dl>、<table>、<address>、<blockquote> 、<form>

常用的內聯元素有:

<a>、<span>、<br>、<i>、<em>、<strong>、<label>、<q>、<var>、<cite>、<code>

常用的內聯塊狀元素有:

<img>、<input>

內聯塊狀元素(inline-block就是同時具備內聯元素、塊狀元素的特點,代碼display:inline-block就是將元素設置為內聯塊狀元素。(css2.1新增),<img>、<input>標簽就是這種內聯塊狀標簽。

inline-block 元素特點:

1、和其他元素都在一行上;

2、元素的高度、寬度、行高以及頂和底邊距都可設置。

二、水平居中  

行內元素和塊級元素不同,對於行內元素,只需在父元素中設置text-align=center即可;

對於塊級元素有以下幾種居中方式:

1.將元素放置在table中,再將table的margin-left和margin-right設置成auto,將table居中,使在其之中的塊級元素葉居中,但是這種方式不符合語義化標簽的規范;

2.將塊級元素轉換行內元素(通過設置display:inline)後再居中.這種方式使居中元素變成行內元素而致使無法設置寬高;

3.設置父元素float:left,position:relative,left:50%;子元素float:left,position:relative,left:-50%,利用相對布局的方式居中.上面三種方式各有優劣,依使用情景具體選擇.

三、垂直居中  

1.對於知道高度的元素可以設置上下padding相等;

2.設置line-height和height相等

3.利用vertical-align,但是這屬性只在tr,td中適用,故可將元素放置入table中在居中

源碼

 代碼如下:

XML/HTML Code復制內容到剪貼板
  1. <!-- 水平居中 -->  
  2. <!-- 行內元素居中只需在父元素中設置text-align即可 -->  
  3. <div class="father">  
  4. <p class="blockCenter">  
  5. hehe</p>  
  6. </div>  
  7. <!-- table居中 -->  
  8. <table class="tableclass">  
  9. <tr>  
  10. <td>  
  11. <ul class="ulclass">  
  12. <li><a href="#">呵</a></li>  
  13. </ul>  
  14. </td>  
  15. </tr>  
  16. </table>  
  17. <table class="tableclass">  
  18. <tr>  
  19. <td>  
  20. <ul class="ulclass">  
  21. <li><a href="#">呵</a></li>  
  22. <li><a href="#">呵</a></li>  
  23. <li><a href="#">呵</a></li>  
  24. </ul>  
  25. </td>  
  26. </tr>  
  27. </table>  
  28. <table class="tableclass">  
  29. <tr>  
  30. <td>  
  31. <ul class="ulclass">  
  32. <li><a href="#">呵</a></li>  
  33. <li><a href="#">呵</a></li>  
  34. <li><a href="#">呵</a></li>  
  35. <li><a href="#">呵</a></li>  
  36. <li><a href="#">呵</a></li>  
  37. </ul>  
  38. </td>  
  39. </tr>  
  40. </table>  
  41. <!-- 將塊及元素變為行內元素在居中 -->  
  42. <ul style="{text-align: center}">  
  43. <li style="{display: inline}">nihao </li>  
  44. </ul>  
  45. <!-- 利用相對布局 -->  
  46. <ul class="relativeCenterFather">  
  47. <li class="relativeCenterChild">你好 </li>  
  48. </ul>  
  49. <!--豎直居中-->  
  50. <!-- 1.設置相同的上下padding -->  
  51. <!-- 2.父元素height和line-height相同 -->  
  52. <hr />  
  53. <div style={background:#000;width:500px;color:#fff;line-height:100px;text-align:center}>  
  54. 我要來場說走就走的旅行   
  55. </div>  
  56. <!--3. vartical-align,這屬性只對tr,td起作用 -->  
  57. <table>  
  58. <tr verticla-align="center" height="100" background="#FF00FF">  
  59. <td>一弦一柱思華年</td>  
  60. </tr>  
  61. </table>  

css樣式

CSS Code復制內容到剪貼板
  1. <style type="text/css">   
  2. .father   
  3. {   
  4. width:500px;   
  5. }   
  6. .inlineCenter   
  7. {   
  8. text-align:center;   
  9. float:left;   
  10. }   
  11. .blockCenter   
  12. {   
  13. width:100px;   
  14. margin-left:auto;   
  15. margin-right:auto;   
  16. text-align:"center"  
  17. }   
  18. .tableclass   
  19. {   
  20. margin-left:auto;   
  21. margin-right:auto;   
  22. }   
  23. .ulclass   
  24. {   
  25. list-style:none;   
  26. margin:0;   
  27. padding:0;   
  28. }   
  29. .ulclass li   
  30. {   
  31. float:left;   
  32. display:inline;   
  33. text-align:center;   
  34. }   
  35. .ulclass li a   
  36. {   
  37. text-align:center;   
  38. float:left;   
  39. background:#316AC5;   
  40. color:#fff;   
  41. }   
  42. .ulclass li a:hover   
  43. {   
  44. background:#fff;   
  45. color:#316AC5;   
  46. }   
  47. .relativeCenterFather   
  48. {   
  49. float:left;   
  50. position:relative;   
  51. left:50%   
  52. }   
  53. .relativeCenterChild   
  54. {   
  55. float:left;   
  56. position:relative;   
  57. left:-50%;   
  58. }   
  59. /* 豎直居中*/  
  60. .wrap   
  61. {   
  62. background:#000;   
  63. width:500px;   
  64. color:#fff;   
  65. height:100px;   
  66. line-height:100px;   
  67. }   
  68. </style>  

以上這篇關於css 行元素和塊元素 相互轉換 居中就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved