南强小屋 Design By 杰米

一、块级元素  行内元素

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

标签:
css,行元素,块元素,居中

南强小屋 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
南强小屋 Design By 杰米

评论“关于css 行元素和块元素 相互转换 居中”

暂无关于css 行元素和块元素 相互转换 居中的评论...

稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!

昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。

这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。

而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?