">
最新公告
  • 欢迎您光临站长源码网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • css使图片居中的方法有哪些

    正文概述 管理员   2024-09-02   10

    本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。

    html

    <div id="pic">
    
           <img src=star.jpg class="logo">
    
    </div>
    

    一、(最简单)文本属性对齐text-align

    text-align控制元素中文本行的对齐方式。可以在img设一个父辈的div,这样img就可以是div的文本,然后用text-align修改div属性。(在父辈元素添加属性)

    注意:子元素必须是inline或inline-block;如果子元素也是div的话,需要给子元素设置display:inline/inline-block. 这里子元素img是inline所以省略这一步。该方法适用于inline元素上。比如img的居中

    css

    #pic {
    
        text-align: center;   /*表示div的子元素居中*/
    
    }
    


    二、巧用margin

    css

    img {
    
        display: block;    
    
        width: 100px;
    
        margin: 0 auto;
    
    }
    

    以上三点缺一不可。

    margin: 0 auto;居中的前提是:

    • 内行元素必须要设置成display: block; img是行内元素必须得设置。如果是input可以不设置。
    • 元素必须要有宽度;自带宽度的除外,比如button和input等。

    根据前提,还可以有另一种方法-修改父元素属性

    #pic {
    
        width: 100px;
    
        margin: 0 auto;
    
    }    /*父元素div属于block,所以不用再设 display: block;*/
    

    综上所属,该方法适用于block元素上。比如div、input的居中

    margin的局限:一行显示两个图片时,margin需要相应修改。

    三、弹性盒布局

    css

    #pic {
    
        display: flex;   
    
        justify-content: center;
    
        }
    

    弹性盒布局可以使用少数几行css实现几乎所有的布局。而且最神的是,即便是n个图片上面两行都可以实现居中,而不必考虑图片布局和位置。

    四、栅格布局

    弹性盒用在导航栏是最普遍的。与之相比,栅格布局是普适的布局系统。

    #pic {
    
        display: grid;   
    
        align-items: center;     /*块级方向(纵向)上的全部栅格元素居中对齐*/
    
        justify-items: center;  /*行内方向(横向)所有的元素中线对齐*/
    
    }
    

    所以能够非常方便的处理多张图片对齐的问题。

    五、绝对定位中对齐

    css

    #pic {
    
        position: relative;   /*设置绝对定位元素(img)的容纳块,如果不设置,那么容纳块默认为body*/
    
    }
    
    .logo {
    
        position: absolute;   
    
        right: 1em; left: 1em;     //表示左右距离相等
    
        margin: 0 auto;         //与方法二相似
    
    }
    

    与方法二最大的区别是,margin的用法是针对block元素的。如果用position就不需要设置block 了。但是position一般用在框架布局上,如果只是图片居中有点大材小用,比较麻烦。不建议。

    六、背景图片居中

    html

    <div></div>
    

    css

    div {
    
        height: 1000px;  /*高度非常重要*/
    
        background: url(star.jpg) no-repeat top center; 
    
    }
    

    前提:只要元素内容是空的,就必须设置高度。因为div内容是空的,所以必须要设置高度,否则div是没有空间的,那背景图片自然也不会显示。如果是body就不用,因为body自带高度。

    设置为背景图片的局限性是无法设置超链接、title、alt等图片的属性。如果不是背景图片,尽量不要用这种格式。


    站长源码网 » css使图片居中的方法有哪些

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    支付宝支付
    余额支付
    ×
    微信扫码支付 0 元