如何靈活的運(yùn)用before和after

經(jīng)常我們在開發(fā)的時(shí)候名扛,我們會(huì)經(jīng)常遇到這樣的小icon的切圖,當(dāng)然通常我們的做法都是直接找ui去要切圖茧痒。最近在開發(fā)自己的項(xiàng)目的時(shí)候肮韧,才突然發(fā)現(xiàn)到 其實(shí)很多簡單的視圖都可以用原生css語言來完成。這里我就簡單的給大家介紹幾個(gè) 當(dāng)作敲門磚用吧旺订。

拋磚引玉

一弄企、 聊天氣泡三角形的實(shí)現(xiàn)

1、

新建一個(gè)div

   <div class="__arrow"></div>
2区拳、

給氣泡設(shè)置初始屬性

      .__arrow{
        display:inline-block;
        padding:10px;
        background:blue;
        color:#FFF;
        border-radius:8px;
        min-width: 50px;
        line-height: 24px;
        height: 24px;
        position:relative;
      }
效果
3拘领、

用偽類before設(shè)置收到的消息

.__arrow:before{
        display:block;
        content:'';
        border-width:8px 8px 8px 8px;
        border-style:solid;
        border-color: transparent #ff4d4d transparent transparent;
        position:absolute;
        left:-16px;
        top:20%;
      }
效果
3、

用偽類after設(shè)置我的消息

.__arrow:after{
        display:block;
        content:'';
        border-width:8px 8px 8px 8px;
        border-style:solid;
        border-color: transparent transparent transparent #ff4d4d;
        position:absolute;
        left:100%;
        top:20%;
      }
效果

二樱调、 加號

加號的效果

上圖就是我想要的加號效果约素。

step1、

新建一個(gè)div

<div class="__plus"></div>
step2笆凌、

寫div寫一個(gè)基礎(chǔ)樣式咯,首先先寫一個(gè)邊框

.__plus{
        width: 100px;
        height: 100px;
        color: black;
        transition: color .25s;
        position: relative;
        border: 1px solid
 }
效果
step3圣猎、

然后利用偽類before來寫一個(gè)橫:

.__plus::before{ 
        content: ''; 
        position: absolute; 
        left: 50%; 
        top: 50%; 
        width: 100px; 
        margin-left: -50px; 
        margin-top: -5px; 
        border-top: 10px solid;
      }
效果
step3、

同樣乞而,最后用偽類after來寫一個(gè)豎:

.__plus::after {
        content: ''; 
        position: absolute; 
        left: 50%;
        top: 50%; 
        height: 100px;
        margin-left: -5px;
        margin-top: -50px; 
        border-left: 10px solid; 
      }
效果

這樣一個(gè)簡單的視圖就完成了送悔,這主要是通過那啥偽類來完成的這里有這么一種情況啊:就是是不是意味著每次我新建一個(gè)不同大小的視圖就要重新寫一遍呢?
回答當(dāng)然不是的放祟。(我是最討厭寫重復(fù)代碼的人)鳍怨,我這里就用stylus做了一個(gè)簡單的封裝,具體的代碼如下:

/**
  $size:視圖的長度
  $plusWidth:加號的寬度
  $color:加號的顏色
 */
plus_icon($size, $plusWidth = 2px, $color = #fff)
  width: $size;
  height: $size;
  color: $color;
  transition: color .25s;
  position: relative;
  &::after
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    height: $size;
    margin-left: -($plusWidth/ 2);
    margin-top: -(0.5 *$size);
    border-left: $plusWidth solid;
  &::before
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    width: $size;
    margin-left: -(0.5 *$size);
    margin-top: -($plusWidth/ 2);
    border-top: $plusWidth solid;

最后在使用的時(shí)候跪妥,直接簡單的:

.add
  plus_icon(12px, 4px)

就能看到效果了

三鞋喇、 齒輪

關(guān)于齒輪呢?我會(huì)用到box-shadow,不清楚的小伙伴可以去看看眉撵。然后進(jìn)入繪畫流程

第一步侦香、 畫出同心圓
.__gear {
        width: 200px;
        height: 200px;
        box-shadow: 0 0 0 50px black inset, 0px 0px 0px 50px white inset;
        margin: 200px auto;
        position: relative;
        border-radius: 50%;
      }
效果
第二步、利用偽類before畫出部分齒輪
.__gear::before {
        content: "";
        display: block;
        width: 20px;
        height: 20px;
        position: absolute;
        border-radius: 5px;
        box-shadow: 90px -16px 0 black, 90px 198px 0 black, -16px 90px 0 black, 198px 90px 0 black;
        -webkit-box-shadow: 90px -16px 0 black, 90px 198px 0 black, -16px 90px 0 black, 198px 90px 0 black;
        -moz-box-shadow: 90px -16px 0 black, 90px 198px 0 black, -16px 90px 0 black, 198px 90px 0 black;
      }
效果
第三步纽疟、利用偽類after畫出剩余部分齒輪

代碼如下:

.__gear::after   {
        content: "";
        display: block;
        width: 20px;
        height: 20px;
        position: absolute;
        border-radius: 5px;
        box-shadow: 90px -16px 0 black, 90px 198px 0 black, -16px 90px 0 black, 198px 90px 0 black;
        -webkit-box-shadow: 90px -16px 0 black, 90px 198px 0 black, -16px 90px 0 black, 198px 90px 0 black;
        -moz-box-shadow: 90px -16px 0 black, 90px 198px 0 black, -16px 90px 0 black, 198px 90px 0 black;
        transform-origin: 100px 100px;
        webkit-transform: rotate(45deg);
        -moz-transform: rotate(45deg);
        -o-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
      }
效果

同理罐韩,我也做了一個(gè)比較通用的方法,也是用stylus寫的,代碼如下:

gear_icon_common($size, $cicle_size, $tri_size)
  $_size01 = (($size/ 2) - ($tri_size/ 2))
  $_size02 = (-0.8 *$tri_size)
  $_size03 = ($size - ($tri_size/ 5))

  content: "";
  display: block;
  width: $tri_size;
  height: $tri_size;
  position: absolute;
  border-radius: $tri_size / 5;
  box-shadow: $_size01 $_size02 0 black, $_size01 $_size03 0 black, $_size02 $_size01 0 black, $_size03 $_size01 0 black;
  -webkit-box-shadow: $_size01 $_size02 0 black, $_size01 $_size03 0 black, $_size02 $_size01 0 black, $_size03 $_size01 0 black;
  -moz-box-shadow: $_size01 $_size02 0 black, $_size01 $_size03 0 black, $_size02 $_size01 0 black, $_size03 $_size01 0 black;

/**
  $size:整個(gè)視圖的寬度
  $cicle_size: 環(huán)的寬度
  $tri_size: 齒輪的寬度
  $Hcolor:環(huán)/齒輪的顏色
  $Icolor:內(nèi)圓的顏色
*/
gear_icon($size, $cicle_size, $tri_size, $Hcolor = #000, $Icolor = #fff)
  width: $size;
  height: $size;
  box-shadow: 0 0 0 $cicle_size $Hcolor inset, 0px 0px 0px $cicle_size $Icolor inset;
  margin: $size auto;
  position: relative;
  border-radius: 50%;
  &::after
    gear_icon_common($size, $cicle_size, $tri_size)
  &::before
    gear_icon_common($size, $cicle_size, $tri_size)
    transform-origin: ($size/ 2) ($size/ 2)
    webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg)

在使用的時(shí)候就直接使用:

 .__artical_content_setting
  gear_icon(14px, 4px, 3px)

寫在最后

最近我發(fā)現(xiàn)我發(fā)表在簡書的文章有很多人評論污朽,首先我很開心能被大家看到散吵,其次我簡單說明一下:
簡書上面很多的技術(shù)類文章呢?我都是當(dāng)作讀書筆記來做的蟆肆,很多用詞用句不是很嚴(yán)謹(jǐn)矾睦,基本都是用到了,覺得不錯(cuò)就寫下來了炎功。

其次就是最近買了一個(gè)服務(wù)器枚冗,想自己獨(dú)立搭建一個(gè)包含后臺(tái)、前端蛇损、android端赁温、小程序端和微信公眾號多端通用的一個(gè)寫作平臺(tái)。因?yàn)樵撇渴鹩倨搿⒑笈_(tái)的知識(shí)鏈比較的薄弱股囊,加上還要定時(shí)去各大媒體投遞一些非技術(shù)類的文章。關(guān)于本站的技術(shù)類文章呢更啄?就不會(huì)定時(shí)的更新稚疹,但還是會(huì)寫一點(diǎn)在開發(fā)中遇到的一些有趣的東西。

最后想說點(diǎn)心里話锈死,因?yàn)楝F(xiàn)在工作也不是很輕松贫堰,外加上自己的技術(shù)內(nèi)涵比較薄弱穆壕,一般主流的時(shí)間和精力都會(huì)用在工作待牵、學(xué)習(xí)和完善自己的想法上面,可能在某些用詞用句上面沒做很大的斟酌喇勋,希望大家海涵(主要也很討厭那些裝逼的人缨该,說一些不太好的裝逼的話 有點(diǎn)惡心)。至于有人私聊我 關(guān)于沒看懂或者描述不清楚的地方呢川背?我很樂意的去為您解決問題贰拿,但是我呢蛤袒,不會(huì)有太多的時(shí)間去看這個(gè)簡書的 我建議是加本人的微信來深入交流,當(dāng)然這段時(shí)間過了之后 我還是會(huì)花大精力在運(yùn)營上面的膨更。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末妙真,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子荚守,更是在濱河造成了極大的恐慌珍德,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件矗漾,死亡現(xiàn)場離奇詭異锈候,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)敞贡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進(jìn)店門泵琳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人誊役,你說我怎么就攤上這事获列。” “怎么了势木?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵蛛倦,是天一觀的道長。 經(jīng)常有香客問我啦桌,道長溯壶,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任甫男,我火速辦了婚禮且改,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘板驳。我一直安慰自己又跛,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布若治。 她就那樣靜靜地躺著慨蓝,像睡著了一般。 火紅的嫁衣襯著肌膚如雪端幼。 梳的紋絲不亂的頭發(fā)上礼烈,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天,我揣著相機(jī)與錄音婆跑,去河邊找鬼此熬。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的犀忱。 我是一名探鬼主播募谎,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼阴汇!你這毒婦竟也來了数冬?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤搀庶,失蹤者是張志新(化名)和其女友劉穎吉执,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體地来,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡戳玫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了未斑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片咕宿。...
    茶點(diǎn)故事閱讀 40,872評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蜡秽,靈堂內(nèi)的尸體忽然破棺而出府阀,到底是詐尸還是另有隱情,我是刑警寧澤芽突,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布试浙,位于F島的核電站,受9級特大地震影響寞蚌,放射性物質(zhì)發(fā)生泄漏田巴。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一挟秤、第九天 我趴在偏房一處隱蔽的房頂上張望壹哺。 院中可真熱鬧,春花似錦艘刚、人聲如沸管宵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽箩朴。三九已至,卻和暖如春秋度,著一層夾襖步出監(jiān)牢的瞬間炸庞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工静陈, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留燕雁,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓鲸拥,卻偏偏與公主長得像拐格,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子刑赶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,876評論 2 361