侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

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

前端  /  管理员 发布于 7年前   230

一、块级元素  行内元素

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. <!-- 行仍鼐又兄恍柙诟冈刂性O置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.O置相同的上下padding -->  
  51. <!-- 2.父元素height和line-height相同 -->  
  52. <hr />  
  53. <div style={background:#000;width:500px;color:#fff;line-height:100px;text-align:center}>  
  54. 我要稣f走就走的旅行   
  55. </div>  
  56. <!--3. vartical-align,@傩灾tr,td起作用 -->  
  57. <table>  
  58. <tr verticla-align="center" height="100" background="#FF00FF">  
  59. <td>一弦一柱思A年</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. /* Q直居中*/  
  60. .wrap   
  61. {   
  62. background:#000;   
  63. width:500px;   
  64. color:#fff;   
  65. height:100px;   
  66. line-height:100px;   
  67. }   
  68. </style>  

以上这篇关于css 行元素和块元素 相互转换 居中就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


  • 上一条:
    使用CheckBox的属性制作纯css动态导航栏
    下一条:
    css position 设置元素的定位方式详解
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客