关于css 行元素和块元素 相互转换 居中

(编辑:jimmy 日期: 2025/1/23 浏览:2)

一、块级元素  行内元素

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 行元素和块元素 相互转换 居中就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

一句话新闻
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。