CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片

這篇文章將為大家詳細(xì)講解有關(guān)CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)擁有一支富有激情的企業(yè)網(wǎng)站制作團(tuán)隊(duì),在互聯(lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)深耕10余年,專業(yè)且經(jīng)驗(yàn)豐富。10余年網(wǎng)站優(yōu)化營(yíng)銷經(jīng)驗(yàn),我們已為千余家中小企業(yè)提供了成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)解決方案,定制網(wǎng)站開發(fā),設(shè)計(jì)滿意,售后服務(wù)無憂。所有客戶皆提供一年免費(fèi)網(wǎng)站維護(hù)!

什么是文字左右環(huán)繞圖片?就是下圖的效果:

CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片

效果的CSS代碼可以點(diǎn)擊這里 查看

在CSS中,并沒有float: center這種設(shè)置,但是我們可以通過一些小技巧來模擬出類似的效果。

經(jīng)常會(huì)有小伙伴問:有float: left和right,為什么沒有float: center?我的答案是:

1.text-align: center已經(jīng)可以實(shí)現(xiàn)內(nèi)聯(lián)元素的居中效果

2.在一行中使文字環(huán)繞顯示在圖片的兩側(cè),這種效果瀏覽器處理起來是非常困難的。除非將文字顯示為兩列,但這是另一個(gè)問題

3.當(dāng)涉及到文本時(shí),float實(shí)際上應(yīng)該被稱為環(huán)繞,float:left的意思是“將這個(gè)元素放置在容器的左側(cè),并將其右側(cè)的所有內(nèi)容都環(huán)繞其顯示”,在這種情況下,我們討論的float:center實(shí)際上是兩側(cè)環(huán)繞,這會(huì)帶來一系列的問題,比如如何確定元素在容器中的“深度”?

為了模擬實(shí)現(xiàn)float: center的效果,我們通過創(chuàng)建兩個(gè)div將文字劃分為兩列,其中居中的圖片寫在第一個(gè)div中:

<div id="container">
  <div id="leftcol">
    <p><img src=".../01.jpg">京都位于本州島的中心附近,在王位移到江戶...
  </div>
  <div id="rightcol">
    <p>因此,京都許多保存下來的地方都是聯(lián)合國(guó)教科文組織世界遺產(chǎn),包括...
  </div>
</div>

首先,我們?cè)O(shè)置兩個(gè)div即.leftcol和.rightcol元素為display: table-cell,同時(shí)將容器.container元素設(shè)置為display: table:

div#container { 
  display: table; 
  width: 80%;
  max-width: 900px;  /* 容器最大寬度900px */
  margin: 0 auto;
  line-height: 1.5;
}
div#leftcol, div#rightcol { 
  display: table-cell; 
  padding: 1em;
}
div#container img {
  width: 55%;  /* 圖片的寬度是第一列div寬度的55% */
  height: auto;
}

這樣,文字就顯示成為表格的兩列了:

CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片

圖片會(huì)按照其該有的樣式顯示在第一列的頂部左側(cè),并且底部與文字的第一行的基線對(duì)齊。

接下來,如果給圖片設(shè)置一個(gè)float:right,它就會(huì)在第一個(gè)div中右側(cè)浮動(dòng),并且文字會(huì)環(huán)繞在圖片的左側(cè)顯示:

CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片

到這里,我們實(shí)現(xiàn)了一個(gè)最傳統(tǒng)的布局:兩列文字,其中一列包含一張浮動(dòng)的圖片。

下面,就要使用一些技巧來實(shí)現(xiàn)左右環(huán)繞的文字效果了。

第一步,通過設(shè)置margin-right屬性負(fù)值,將圖片右移一定的距離:

div#container img {
  float: right;
  width: 55%;
  height: auto;
  margin-right: -20%;  /* 圖片向右移動(dòng)第一個(gè)div寬度20%的距離 */
  margin-left: 20px;
  margin-bottom: 20px;
}

margin-left和margin-bottom屬性設(shè)置圖片與左側(cè)和下方的文字都間距20px。

這個(gè)時(shí)候圖片會(huì)和第二列的文字顯示重合了:

CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片

第二步,通過:before偽元素在第二個(gè)div中生成一個(gè)元素,它不包含任何內(nèi)容,僅僅是為了浮動(dòng)后讓文字環(huán)繞它。

div#rightcol:before { 
  content: " "; 
  float: left; 
  width: 25%;
  padding-top: 102%;
}

這個(gè)偽元素被設(shè)置為左浮動(dòng),并且它的寬度與圖片右移的距離加起來剛好是圖片的寬度。

padding-top屬性設(shè)置的稍微大一點(diǎn),這樣文字與圖片能夠空出一些距離。

如果給這個(gè)沒有任何內(nèi)容的偽元素添加一個(gè)紅色的邊框,我們就可以看到它的位置:

CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片

這個(gè)空偽元素的實(shí)際作用就是將與圖片重合的文字隔開,并使它們環(huán)繞,這樣就模擬出了右側(cè)文字環(huán)繞圖片的效果,而實(shí)際上文字環(huán)繞的是偽元素。

這種環(huán)繞方式有一個(gè)限制,就是圖片必須位于div的頂部,我們不能在垂直方向上任意放置圖片。

最后,再設(shè)置一些美化的樣式和自適應(yīng)的代碼,最終的效果就實(shí)現(xiàn)了:

CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片 

關(guān)于“CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

當(dāng)前文章:CSS中如何模擬float實(shí)現(xiàn)center文字左右環(huán)繞圖片
本文URL:http://bm7419.com/article26/igsejg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、Google、網(wǎng)站維護(hù)搜索引擎優(yōu)化、電子商務(wù)ChatGPT

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司