最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

HTML对于元素水平垂直居中的探讨_HTML/Xhtml_网页制作

来源:动视网 责编:小采 时间:2020-11-27 16:49:10
文档

HTML对于元素水平垂直居中的探讨_HTML/Xhtml_网页制作

HTML对于元素水平垂直居中的探讨_HTML/Xhtml_网页制作:我们在设计页面的时候,经常要把DIV居中显示,而且是相对页面窗口水平和垂直方向居中显示,如让登录窗口居中显示。 到现在为止,探讨了很多种方法。 HTML: XML/HTML Code复制内容到剪贴板 body> div class=maxbox
推荐度:
导读HTML对于元素水平垂直居中的探讨_HTML/Xhtml_网页制作:我们在设计页面的时候,经常要把DIV居中显示,而且是相对页面窗口水平和垂直方向居中显示,如让登录窗口居中显示。 到现在为止,探讨了很多种方法。 HTML: XML/HTML Code复制内容到剪贴板 body> div class=maxbox
 我们在设计页面的时候,经常要把DIV居中显示,而且是相对页面窗口水平和垂直方向居中显示,如让登录窗口居中显示。

到现在为止,探讨了很多种方法。

HTML:

XML/HTML Code复制内容到剪贴板

  • 效果图(下面几种方法效果图一样):

    第一种: CSS绝对定位

    主要利用绝对定位,再用margin调整到中间位置。

    父元素:

    CSS Code复制内容到剪贴板
    
    
    1. .maxbox{
    2. position: relative;
    3. width: 500px;
    4. height: 500px;
    5. margin: 5px;
    6. box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.8), -1px -1px 1px rgba(0, 0, 0, 0.8);
    7. }

    子元素:

    CSS Code复制内容到剪贴板
    
    
    1. .minbox{
    2. width: 200px;
    3. height: 200px;
    4. box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.8), -1px -1px 1px rgba(0, 0, 0, 0.8);
    5. }

    水平垂直居中对齐:

    CSS Code复制内容到剪贴板
    
    
    1. .align-center{
    2. position: absolute;
    3. left: 50%;
    4. top: 50%;
    5. margin-left: -100px; /*width/-2*/
    6. margin-top: -100px; /*height/-2*/
    7. }

    第二种: CSS绝对定位 + Javascript/JQuery

    主要利用绝对定位,再用Javascript/JQuery调整到中间位置。相比第一种方法,此方法提高了class的灵活性。

    父元素:

    CSS Code复制内容到剪贴板
    
    
    1. .maxbox{
    2. position: relative;
    3. width: 500px;
    4. height: 500px;
    5. margin: 5px;
    6. box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.8), -1px -1px 1px rgba(0, 0, 0, 0.8);
    7. }

    子元素:

    CSS Code复制内容到剪贴板
    
    
    1. .minbox{
    2. width: 200px;
    3. height: 200px;
    4. box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.8), -1px -1px 1px rgba(0, 0, 0, 0.8);
    5. }

    水平垂直居中对齐:

    CSS Code复制内容到剪贴板
    
    
    1. .align-center{
    2. position: absolute;
    3. left: 50%;
    4. top: 50%;
    5. }

    JQuery:

    JavaScript Code复制内容到剪贴板
    
    
    1. $(function(){
    2. $(".align-center").css(
    3. {
    4. "margin-left": ($(".align-center").width()/-2),
    5. "margin-top": ($(".align-center").height()/-2)
    6. }
    7. );
    8. });

    第三种: CSS3绝对定位 + 位移

    使用绝对定位与CSS3的 transform: translate同样也可以达到效果。

    父元素:

    CSS Code复制内容到剪贴板
    
    
    1. .maxbox{
    2. position: relative;
    3. width: 500px;
    4. height: 500px;
    5. margin: 5px;
    6. box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.8), -1px -1px 1px rgba(0, 0, 0, 0.8);
    7. }

    子元素:

    CSS Code复制内容到剪贴板
    
    
    1. .minbox{
    2. width: 200px;
    3. height: 200px;
    4. box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.8), -1px -1px 1px rgba(0, 0, 0, 0.8);
    5. }

    水平垂直居中对齐:

    CSS Code复制内容到剪贴板
    
    
    1. .align-center{
    2. position: absolute;
    3. top: 50%;
    4. left: 50%;
    5. -webkit-transform: translate(-50%, -50%);
    6. -moz-transform: translate(-50%, -50%);
    7. transform: translate(-50%, -50%); /*向左向上位移*/
    8. }

    第四种: Flexbox: [伸缩布局盒模型]

    要让元素水平垂直,对于Flexbox模型来说太容易了。

    这里得改变一下HTML:

    XML/HTML Code复制内容到剪贴板
    
    
  • 父元素:

    CSS Code复制内容到剪贴板
    
    
    1. .maxbox{
    2. position: relative;
    3. width: 500px;
    4. height: 500px;
    5. margin: 5px;
    6. box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.8), -1px -1px 1px rgba(0, 0, 0, 0.8);
    7. }

    子元素:

    C# Code复制内容到剪贴板
    
    
    1. .minbox{
    2. width: 200px;
    3. height: 200px;
    4. box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.8), -1px -1px 1px rgba(0, 0, 0, 0.8);
    5. }

    水平垂直居中对齐:

    CSS Code复制内容到剪贴板
    
    
    1. .align-center{
    2. display: flex;
    3. display: -webkit-flex; /*兼容问题*/
    4. justify-content: center;
    5. align-items: center;
    6. }

    几种方法的比较:

    第一种CSS绝对定位margin调整,兼容性很好但是欠缺灵活性。如果有很多box里需要水平垂直居中,因其width,height不同而需要写不同的 .align-center 。
    第二种使用脚本语言,兼容性很好且弥补了第一种的缺点。不因width,height的改变而影响水平垂直居中的效果。
    第三种使用CSS3的一些新的属性,兼容IE10, Chrome, Firefox, 和 Opera。兼容性不太很好,不因width,height的改变而影响水平垂直居中的效果。
    使用Flexbox模型,兼容Firefox、Opera 和 Chrome,IE全军覆没。也是不因width,height的改变而影响水平垂直居中的效果。

    文档

    HTML对于元素水平垂直居中的探讨_HTML/Xhtml_网页制作

    HTML对于元素水平垂直居中的探讨_HTML/Xhtml_网页制作:我们在设计页面的时候,经常要把DIV居中显示,而且是相对页面窗口水平和垂直方向居中显示,如让登录窗口居中显示。 到现在为止,探讨了很多种方法。 HTML: XML/HTML Code复制内容到剪贴板 body> div class=maxbox
    推荐度:
    标签: 居中 元素 html
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top