成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

老板要求我實現一只碎片化效果的鳥,難得倒我?

開發
老板要求我實現每一只動物都是一塊一塊碎片組成的,并且每一次切換的時候,碎片都有一種重組動畫效果,實現起來不難,分享給大家。

老板:別人有的,我們也要有!

效果如下,每一只動物都是一塊一塊碎片組成的,并且每一次切換的時候,碎片都有一種重組動畫效果,如下:

實現起來不難,分享給大家!

一探究竟

進到這個網站中看,可以看到每一只動物都是由無數個碎片DOM節點疊加而成的,而這些碎片是怎么畫的呢,可以看出用了兩個樣式:

  • clip-path:碎片形狀的繪制
  • background-color:碎片背景顏色

如果對 clip-path 這個樣式感興趣的,可以去 MDN 文檔上看~

碎片數據獲取

既然我們知道了這些動物是由碎片疊加而來,那么我們可以去獲取每一個碎片的 clip-path、background-color,并存入到一個數組中。

這對于我們前端來說并非難事,只需要通過 DOM 操作即可收集數據,代碼如下:

將上面代碼復制到網站的控制臺中去進行運行,即可或者這只動物的所有碎片的數據:

接著你如果想獲取多個動物的碎片數據,無非就是切換一個動物,就執行一下這段代碼,這樣就可以獲取到很多只動物的碎片數據了~

我將這些數據集合收集到 data.json 文件中:

動物繪制

有了數據之后我們就可以開始繪制動物了,只需要通過簡單的循環以及樣式賦值,即可繪制成功

切換動畫

接下來需要完成動畫切換,以及切換動畫,其實也不難,只需要給每個碎片加上過渡動畫,并且增加一個按鈕實現數據索引切換即可:

完整源碼

獲取碎片數據代碼:

let shards = document.querySelectorAll('.shard')
const res = []
shards.forEach(ele => {
    const allStyles = window.getComputedStyle(ele)
    res.push({
        clipPath: allStyles.getPropertyValue('clip-path'),
        backgroundColor: allStyles.getPropertyValue('background-color')
    })
})
console.log(JSON.stringify(res))
<template>
  <Button @click="changeAnimal">切換</Button>
  <div class="animal-container">
    <template v-for="(item, index) in currentData" :key="index">
      <div
        class="clip-item"
        :style="{
          backgroundColor: item.backgroundColor,
          clipPath: item.clipPath,
          transitionDelay: `${index * 15}ms`,
        }"
      ></div>
    </template>
  </div>
</template>

<script lang="ts" setup>
import { ref } from 'vue';
import { Button } from 'ant-design-vue';
import data from './data.json';

const currentIndex = ref(0);
const currentData = ref(data[0]);
const length = data.length;
const changeAnimal = () => {
  currentIndex.value++;
  //   索引到最后了,重置為 0
  if (currentIndex.value >= length) {
    currentIndex.value = 0;
  }
  currentData.value = data[currentIndex.value];
};
</script>

<style scoped lang="less">
.animal-container {
  width: 800px;
  height: 600px;
  position: relative;

  .clip-item {
    position: absolute;
    width: 100%;
    height: 100%;

    // 動畫過渡效果
    transition-property: all;
    transition-duration: 1000ms;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  }
}
</style>
責任編輯:趙寧寧 來源: 前端之神
相關推薦

2015-04-15 10:29:38

Linux 4.0

2017-09-12 12:13:57

夢想 咸魚

2019-10-30 15:27:28

Google谷歌Alphabet

2017-11-15 12:57:57

爬蟲爬取數據分析

2022-10-18 22:20:36

CSS矩形border

2017-11-09 19:22:08

華為

2022-03-02 09:40:26

微軟Windows 8ASCII 貓

2020-06-02 09:22:45

腳本CPUDDG

2009-11-24 09:31:38

2021-08-28 05:05:07

碎片化路徑經驗

2015-07-28 17:28:15

程序員技能

2013-08-02 11:24:47

Android碎片化圖解生態碎Androi

2014-02-19 11:12:35

2024-06-11 08:32:37

JavaScrip隨機樹UI

2010-04-19 11:53:28

富士康

2020-07-15 07:40:20

Linux命令JavaScript

2012-07-16 09:42:09

虛擬化

2023-12-18 08:42:49

Cat.1窄帶通信

2016-06-06 10:12:16

攝像頭智能硬件

2021-05-28 11:10:18

區塊鏈加密貨幣比特幣
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品久久国产老人久久综合 | www.男人天堂.com | 精品一区av | 日本小视频网站 | 欧美性大战久久久久久久蜜臀 | 成人欧美一区二区 | 午夜三级在线观看 | 天天操网 | 五十女人一级毛片 | 91国内产香蕉 | 久久综合香蕉 | 福利精品在线观看 | 激情在线视频 | 成人天堂 | 精品日本中文字幕 | 亚洲看片网站 | 久久久婷婷 | 农村真人裸体丰满少妇毛片 | 精品丝袜在线 | 精久久久 | 最新av中文字幕 | 成人精品国产 | 超碰成人免费观看 | 久久99精品久久久久久琪琪 | 日韩中文在线 | 最新国产精品视频 | 精品国产青草久久久久96 | 午夜精品久久久久久久久久久久久 | 国产精品成人国产乱一区 | 国产精品精品3d动漫 | 欧美一级免费看 | 亚洲一二三区精品 | www久久久 | 日本免费在线 | 日韩亚洲视频在线 | 亚洲精品无 | 人人射人人 | 精品国产一级片 | 国产成人免费视频网站高清观看视频 | 国产成人精品一区二 | 亚洲精品久久久一区二区三区 |