成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

前端每日實戰(zhàn):129# 視頻演示如何用純 CSS 和原生 JS 創(chuàng)作一個條紋錯覺動畫

alexnevsky / 1502人閱讀

摘要:效果預(yù)覽按下右側(cè)的點擊預(yù)覽按鈕可以在當(dāng)前頁面預(yù)覽,點擊鏈接可以全屏預(yù)覽??山换ヒ曨l此視頻是可以交互的,你可以隨時暫停視頻,編輯視頻中的代碼。接下來我們來揭秘真相。

效果預(yù)覽

按下右側(cè)的“點擊預(yù)覽”按鈕可以在當(dāng)前頁面預(yù)覽,點擊鏈接可以全屏預(yù)覽。

https://codepen.io/comehope/pen/qMPQPx

可交互視頻

此視頻是可以交互的,你可以隨時暫停視頻,編輯視頻中的代碼。

請用 chrome, safari, edge 打開觀看。

https://scrimba.com/p/pEgDAM/cMGa4TQ

源代碼下載

每日前端實戰(zhàn)系列的全部源代碼請從 github 下載:

https://github.com/comehope/front-end-daily-challenges

代碼解讀

定義 dom,容器中包含 2 個元素,分別代表 2 條軌道:

居中顯示:

body {
    margin: 0;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #999;
}

定義容器尺寸和子元素的布局方式:

.container {
    font-size: 30px;
    width: calc(13em + 0.5em);
    height: 8em;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

定義 2 個色值,一個亮的和一個暗的:

.container {
    --dark: #222;
    --light: #ffffd;
}

畫出 2 條軌道的輪廓:

.track {
    width: inherit;
    height: 2em;
    border: 1px solid var(--dark);
}

為 2 條軌道的背景圖案,圖案是明暗相間的條紋,但第 2 條軌道要錯半個格:

.track {
    background: linear-gradient(
        90deg,
        var(--dark) 50%,
        var(--light) 50%
    );
    background-size: 1em;
}

.track:nth-child(2) {
    background-position: 0.5em;
}

用偽元素畫出 2 個矩形:

.track {
    position: relative;
    display: flex;
    align-items: center;
}

.track::before {
    content: "";
    position: absolute;
    width: 2em;
    height: 0.8em;
    background-color: var(--light);
}

讓這 2 個矩形在軌道上往復(fù)移動:

.track::before {
    animation: move 5s linear infinite alternate;
}

@keyframes move {
    from {
        left: 0;
    }
    
    to {
        left: calc(100% - 2em);
    }
}

此時,兩個矩形看起來是一先一后地前進(jìn)的,但實際上它們是在同一時刻開始并且以相同的速度在移動。接下來我們來揭秘真相。

在 dom 中增加一個子元素,作為按鈕;

Show me the truth

設(shè)置按鈕的樣式:

.toggle {
    order: -1;
    width: 10em;
    height: 2em;
    border: 2px solid var(--dark);
    border-radius: 0.2em;
    font-size: 0.5em;
    font-family: sans-serif;
    font-weight: bold;
    color: black;
    text-align: center;
    line-height: 2em;
    cursor: pointer;
    user-select: none;
}

為按鈕設(shè)置與軌道風(fēng)格類似的背景,以及鼠標(biāo)懸停效果:

.toggle {
    background-image: linear-gradient(to right, #ffffd 50%, #999 50%);
    background-size: 1em;
    transition: 0.5s;
}

.toggle:hover {
    background-position: 5em;
}

增加一段點擊按鈕時觸發(fā)的腳本,為軌道元素切換樣式:

let $toggle = document.getElementsByClassName("toggle")[0]
let $tracks = Array.from(document.getElementsByClassName("track"))

$toggle.addEventListener("click", function() {
    $tracks.forEach(track => track.classList.toggle("highlights"))
})

終于,謎底就在切換樣式之后被揭曉了:

.track::before {
    box-sizing: border-box;
    border: solid var(--dark);
    border-width: 0;
}

.track.highlights::before {
    background-color: white;
    border-width: 0.1em;
}

大功告成!

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/113908.html

相關(guān)文章

  • 前端每日實戰(zhàn)129# 視頻演示何用 CSS 原生 JS 創(chuàng)作一個條紋錯覺動畫

    摘要:效果預(yù)覽按下右側(cè)的點擊預(yù)覽按鈕可以在當(dāng)前頁面預(yù)覽,點擊鏈接可以全屏預(yù)覽。可交互視頻此視頻是可以交互的,你可以隨時暫停視頻,編輯視頻中的代碼。接下來我們來揭秘真相。 showImg(https://segmentfault.com/img/bVbgztX?w=400&h=293); 效果預(yù)覽 按下右側(cè)的點擊預(yù)覽按鈕可以在當(dāng)前頁面預(yù)覽,點擊鏈接可以全屏預(yù)覽。 https://codepen...

    flybywind 評論0 收藏0
  • 前端每日實戰(zhàn) 2018 年 9 月份項目匯總(共 26 個項目)

    摘要:過往項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份發(fā)布的項目前端每日實戰(zhàn)專欄每天分解一個前端項目,用視頻記錄編碼過程,再配合詳細(xì)的代碼解讀,是學(xué)習(xí)前端開發(fā)的活的參考書 過往項目 2018 年 8 月份項目匯總(共 29 個項目) 2018 年 7 月份項目匯總(共 29 個項目) 2018 年 6 月份項目匯總(...

    lavnFan 評論0 收藏0
  • 前端每日實戰(zhàn) 2018 年 9 月份項目匯總(共 26 個項目)

    摘要:過往項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份項目匯總共個項目年月份發(fā)布的項目前端每日實戰(zhàn)專欄每天分解一個前端項目,用視頻記錄編碼過程,再配合詳細(xì)的代碼解讀,是學(xué)習(xí)前端開發(fā)的活的參考書 過往項目 2018 年 8 月份項目匯總(共 29 個項目) 2018 年 7 月份項目匯總(共 29 個項目) 2018 年 6 月份項目匯總(...

    whatsns 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<