github的黑夜模式小猫咪动画源码

2023-05-11 13:16:59 浏览数 (3)

昨天觉得github上的小猫咪黑夜模式切换很可爱,想要~ 。于是花了点时间扒了下来放在了自己的博客上。 秉着开源精神,将源码分享给大家。
html
代码语言:javascript复制
<!-- 暗黑模式 -->
<div class="profile-color-modes js-promo-color-modes-banner-profile">
    <svg aria-hidden="true" height="45" viewBox="0 0 106 60" fill="none" stroke-width="3"
         stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg">
        <g class="profile-color-modes-illu-group profile-color-modes-illu-red">
            <path d="M37.5 58.5V57.5C37.5 49.768 43.768 43.5 51.5 43.5V43.5C59.232 43.5 65.5 49.768 65.5 57.5V58.5"></path>
        </g>
        <g class="profile-color-modes-illu-group profile-color-modes-illu-orange">
            <path d="M104.07 58.5C103.401 55.092 97.7635 54.3869 95.5375 57.489C97.4039 54.6411 99.7685 48.8845 94.6889 46.6592C89.4817 44.378 86.1428 50.1604 85.3786 54.1158C85.9519 50.4768 83.7226 43.294 78.219 44.6737C72.7154 46.0534 72.7793 51.3754 74.4992 55.489C74.169 54.7601 72.4917 53.3567 70.5 52.8196"></path>
        </g>
        <g class="profile-color-modes-illu-group profile-color-modes-illu-purple">
            <path d="M5.51109 58.5V52.5C5.51109 41.4543 14.4654 32.5 25.5111 32.5C31.4845 32.5 36.8464 35.1188 40.5111 39.2709C40.7212 39.5089 40.9258 39.7521 41.1245 40"></path>
            <path d="M27.511 49.5C29.6777 49.5 28.911 49.5 32.511 49.5"></path>
            <path d="M27.511 56.5C29.6776 56.5 26.911 56.5 30.511 56.5"></path>
        </g>
        <g class="profile-color-modes-illu-group profile-color-modes-illu-green">
            <circle cx="5.5" cy="12.5" r="4"></circle>
            <circle cx="18.5" cy="5.5" r="4"></circle>
            <path d="M18.5 9.5L18.5 27.5"></path>
            <path d="M18.5 23.5C6 23.5 5.5 23.6064 5.5 16.5"></path>
        </g>
        <g class="profile-color-modes-illu-group profile-color-modes-illu-blue">
            <g class="profile-color-modes-illu-frame">
                <path d="M40.6983 31.5C40.5387 29.6246 40.6456 28.0199 41.1762 27.2317C42.9939 24.5312 49.7417 26.6027 52.5428 30.2409C54.2551 29.8552 56.0796 29.6619 57.9731 29.6619C59.8169 29.6619 61.5953 29.8452 63.2682 30.211C66.0833 26.5913 72.799 24.5386 74.6117 27.2317C75.6839 28.8246 75.0259 33.7525 73.9345 37.5094C74.2013 37.9848 74.4422 38.4817 74.6555 39"></path>
            </g>
            <g class="profile-color-modes-illu-frame">
                <path d="M41.508 31.5C41.6336 31.2259 41.7672 30.9582 41.9085 30.6968C40.7845 26.9182 40.086 21.8512 41.1762 20.2317C42.9939 17.5312 49.7417 19.6027 52.5428 23.2409C54.2551 22.8552 56.0796 22.6619 57.9731 22.6619C59.8169 22.6619 61.5953 22.8452 63.2682 23.211C66.0833 19.5913 72.799 17.5386 74.6117 20.2317C75.6839 21.8246 75.0259 26.7525 73.9345 30.5094C75.1352 32.6488 75.811 35.2229 75.811 38.2283C75.811 38.49 75.8058 38.7472 75.7957 39"></path>
                <path d="M49.4996 33V35.6757"></path>
                <path d="M67.3375 33V35.6757"></path>
            </g>
            <g class="profile-color-modes-illu-frame">
                <path d="M41.508 31.5C41.6336 31.2259 41.7672 30.9582 41.9085 30.6968C40.7845 26.9182 40.086 21.8512 41.1762 20.2317C42.9939 17.5312 49.7417 19.6027 52.5428 23.2409C54.2551 22.8552 56.0796 22.6619 57.9731 22.6619C59.8169 22.6619 61.5953 22.8452 63.2682 23.211C66.0833 19.5913 72.799 17.5386 74.6117 20.2317C75.6839 21.8246 75.0259 26.7525 73.9345 30.5094C75.1352 32.6488 75.811 35.2229 75.811 38.2283C75.811 38.49 75.8058 38.7472 75.7957 39"></path>
            </g>
            <g class="profile-color-modes-illu-frame">
                <path d="M41.508 31.5C41.6336 31.2259 41.7672 30.9582 41.9085 30.6968C40.7845 26.9182 40.086 21.8512 41.1762 20.2317C42.9939 17.5312 49.7417 19.6027 52.5428 23.2409C54.2551 22.8552 56.0796 22.6619 57.9731 22.6619C59.8169 22.6619 61.5953 22.8452 63.2682 23.211C66.0833 19.5913 72.799 17.5386 74.6117 20.2317C75.6839 21.8246 75.0259 26.7525 73.9345 30.5094C75.1352 32.6488 75.811 35.2229 75.811 38.2283C75.811 38.49 75.8058 38.7472 75.7957 39"></path>
                <path d="M49.4996 33V35.6757"></path>
                <path d="M67.3375 33V35.6757"></path>
            </g>
            <g class="profile-color-modes-illu-frame">
                <path d="M41.508 31.5C41.6336 31.2259 41.7672 30.9582 41.9085 30.6968C40.7845 26.9182 40.086 21.8512 41.1762 20.2317C42.9939 17.5312 49.7417 19.6027 52.5428 23.2409C54.2551 22.8552 56.0796 22.6619 57.9731 22.6619C59.8169 22.6619 61.5953 22.8452 63.2682 23.211C66.0833 19.5913 72.799 17.5386 74.6117 20.2317C75.6839 21.8246 75.0259 26.7525 73.9345 30.5094C75.1352 32.6488 75.811 35.2229 75.811 38.2283C75.811 38.49 75.8058 38.7472 75.7957 39"></path>
            </g>
            <g class="profile-color-modes-illu-frame">
                <path d="M41.508 31.5C41.6336 31.2259 41.7672 30.9582 41.9085 30.6968C40.7845 26.9182 40.086 21.8512 41.1762 20.2317C42.9939 17.5312 49.7417 19.6027 52.5428 23.2409C54.2551 22.8552 56.0796 22.6619 57.9731 22.6619C59.8169 22.6619 61.5953 22.8452 63.2682 23.211C66.0833 19.5913 72.799 17.5386 74.6117 20.2317C75.6839 21.8246 75.0259 26.7525 73.9345 30.5094C75.1352 32.6488 75.811 35.2229 75.811 38.2283C75.811 38.49 75.8058 38.7472 75.7957 39"></path>
                <path d="M49.4996 33V35.6757"></path>
                <path d="M67.3375 33V35.6757"></path>
            </g>
            <g class="profile-color-modes-illu-frame">
                <path d="M73.4999 40.2236C74.9709 38.2049 75.8108 35.5791 75.8108 32.2283C75.8108 29.2229 75.1351 26.6488 73.9344 24.5094C75.0258 20.7525 75.6838 15.8246 74.6116 14.2317C72.7989 11.5386 66.0832 13.5913 63.2681 17.211C61.5952 16.8452 59.8167 16.6619 57.973 16.6619C56.0795 16.6619 54.2549 16.8552 52.5427 17.2409C49.7416 13.6027 42.9938 11.5312 41.176 14.2317C40.0859 15.8512 40.7843 20.9182 41.9084 24.6968C41.003 26.3716 40.4146 28.3065 40.2129 30.5"></path>
                <path d="M82.9458 30.5471L76.8413 31.657"></path>
                <path d="M76.2867 34.4319L81.8362 37.7616"></path>
                <path d="M49.4995 27.8242V30.4999"></path>
                <path d="M67.3374 27.8242V30.4998"></path>
            </g>
            <g class="profile-color-modes-illu-frame">
                <path d="M45.3697 34.2658C41.8877 32.1376 39.7113 28.6222 39.7113 23.2283C39.7113 20.3101 40.3483 17.7986 41.4845 15.6968C40.3605 11.9182 39.662 6.85125 40.7522 5.23168C42.5699 2.53117 49.3177 4.6027 52.1188 8.24095C53.831 7.85521 55.6556 7.66186 57.5491 7.66186C59.3929 7.66186 61.1713 7.84519 62.8442 8.21095C65.6593 4.59134 72.375 2.5386 74.1877 5.23168C75.2599 6.82461 74.6019 11.7525 73.5105 15.5094C74.7112 17.6488 75.3869 20.2229 75.3869 23.2283C75.3869 28.6222 73.2105 32.1376 69.7285 34.2658C70.8603 35.5363 72.6057 38.3556 73.3076 40"></path>
                <path d="M49.0747 19.8242V22.4999"></path>
                <path d="M54.0991 28C54.6651 29.0893 55.7863 30.0812 57.9929 30.0812C59.0642 30.0812 59.8797 29.8461 60.5 29.4788"></path>
                <path d="M66.9126 19.8242V22.4999"></path>
                <path d="M33.2533 20.0237L39.0723 22.1767"></path>
                <path d="M39.1369 25.0058L33.0935 27.3212"></path>
                <path d="M81.8442 19.022L76.0252 21.1751"></path>
                <path d="M75.961 24.0041L82.0045 26.3196"></path>
            </g>
            <g class="profile-color-modes-illu-frame">
                <path d="M73.4999 40.2236C74.9709 38.2049 75.8108 35.5791 75.8108 32.2283C75.8108 29.2229 75.1351 26.6488 73.9344 24.5094C75.0258 20.7525 75.6838 15.8246 74.6116 14.2317C72.7989 11.5386 66.0832 13.5913 63.2681 17.211C61.5952 16.8452 59.8167 16.6619 57.973 16.6619C56.0795 16.6619 54.2549 16.8552 52.5427 17.2409C49.7416 13.6027 42.9938 11.5312 41.176 14.2317C40.0859 15.8512 40.7843 20.9182 41.9084 24.6968C41.003 26.3716 40.4146 28.3065 40.2129 30.5"></path>
                <path d="M82.9458 30.5471L76.8413 31.657"></path>
                <path d="M76.2867 34.4319L81.8362 37.7616"></path>
                <path d="M49.4995 27.8242V30.4999"></path>
                <path d="M67.3374 27.8242V30.4998"></path>
            </g>
            <g class="profile-color-modes-illu-frame">
                <path d="M40.6983 31.5C40.5387 29.6246 40.6456 28.0199 41.1762 27.2317C42.9939 24.5312 49.7417 26.6027 52.5428 30.2409C54.2551 29.8552 56.0796 29.6619 57.9731 29.6619C59.8169 29.6619 61.5953 29.8452 63.2682 30.211C66.0833 26.5913 72.799 24.5386 74.6117 27.2317C75.6839 28.8246 75.0259 33.7525 73.9345 37.5094C74.2013 37.9848 74.4422 38.4817 74.6555 39"></path>
            </g>
        </g>
    </svg>
    <span class="profile-color-modes-toggle js-promo-color-modes-toggle" role="checkbox"
          aria-checked="false" aria-label="Toggle dark mode" tabindex="0">
        <div class="profile-color-modes-toggle-track"></div>
        <div class="profile-color-modes-toggle-thumb js-promo-color-modes-thumb">
          <svg style="fill: #ffdf5d; margin: 7px 0 0 7px;" aria-hidden="true"
               width="14" height="13" viewBox="0 0 14 13" xmlns="http://www.w3.org/2000/svg">
            <path fill-rule="evenodd" clip-rule="evenodd"
                  d="M4.52208 7.71754C7.5782 7.71754 10.0557 5.24006 10.0557 2.18394C10.0557 1.93498 10.0392 1.68986 10.0074 1.44961C9.95801 1.07727 10.3495 0.771159 10.6474 0.99992C12.1153 2.12716 13.0615 3.89999 13.0615 5.89383C13.0615 9.29958 10.3006 12.0605 6.89485 12.0605C3.95334 12.0605 1.49286 10.001 0.876728 7.24527C0.794841 6.87902 1.23668 6.65289 1.55321 6.85451C2.41106 7.40095 3.4296 7.71754 4.52208 7.71754Z"></path>
          </svg>
        </div>
      </span>
</div>

css

代码语言:javascript复制
/* 暗夜模式 */
// style
:root,[data-color-mode=light] {
    --color-text-primary: #24292e;
    --color-bg-canvas: #fff;
    --color-scale-gray-3: #d1d5da;
    --color-scale-purple-8: #3a1d6e;
    --color-scale-white: #fff;
    --color-scale-purple-9: #29134e;
    --color-scale-gray-8: #2f363d;
    --color-scale-purple-6: #5a32a3;
    --color-scale-yellow-4: #ffdf5d;
    --color-scale-yellow-0: #fffdef;
    --color-auto-gray-3: #d1d5da;
    --color-scale-red-5: #d73a49;
    --color-scale-orange-3: #ffab70;
    --color-scale-purple-5: #6f42c1;
    --color-scale-green-3: #85e89d;
    --color-scale-blue-4: #2188ff;
    --color-scale-gray-6: #586069;
}

[data-color-mode=dark] {
    --color-text-primary: #c9d1d9;
    --color-bg-canvas: #0d1117;
    --color-scale-gray-3: #8b949e;
    --color-scale-purple-8: #3c1e70;
    --color-scale-white: #f0f6fc;
    --color-scale-purple-9: #271052;
    --color-scale-gray-8: #161b22;
    --color-scale-purple-6: #6e40c9;
    --color-scale-yellow-4: #bb8009;
    --color-scale-yellow-0: #f8e3a1;
    --color-auto-gray-3: #30363d;
    --color-scale-red-5: #da3633;
    --color-scale-orange-3: #f0883e;
    --color-scale-purple-5: #8957e5;
    --color-scale-green-3: #3fb950;
    --color-scale-blue-4: #388bfd;
    --color-scale-gray-6: #30363d;
}

/* 暗夜模式 */
[data-color-mode] {
    color: var(--color-text-primary);
    background-color: var(--color-bg-canvas)
}

:root,[data-color-mode=light] {
    color-scheme: light
}

[data-color-mode=dark] {
    color-scheme: dark
}

// style end
:root,[data-color-mode=light] {
    --color-profile-color-modes-toggle-track-border:var(--color-scale-gray-3)}

[data-color-mode=dark] {
    --color-profile-color-modes-toggle-track-border:var(--color-scale-purple-8)}

:root,[data-color-mode=light] {
    --color-profile-color-modes-toggle-track-bg:var(--color-scale-white)}

[data-color-mode=dark] {
    --color-profile-color-modes-toggle-track-bg:var(--color-scale-purple-9)}

:root,[data-color-mode=light] {
    --color-profile-color-modes-toggle-thumb-bg:var(--color-scale-gray-8)}

[data-color-mode=dark] {
    --color-profile-color-modes-toggle-thumb-bg:var(--color-scale-purple-6)}

:root,[data-color-mode=light] {
    --color-profile-color-modes-toggle-moon:var(--color-scale-yellow-4)}

[data-color-mode=dark] {
    --color-profile-color-modes-toggle-moon:var(--color-scale-yellow-0)}

//color
.profile-color-modes {
    display: block;
    position: relative;
    padding-right: 32px
}

.profile-color-modes-toggle {
    position: absolute;
    top: 12px;
    right: 0
}

.profile-color-modes-toggle-track {
    width: 42px;
    height: 24px;
    border-radius: 24px;
    border: 3px solid var(--color-profile-color-modes-toggle-track-border);
    background-color: var(--color-profile-color-modes-toggle-track-bg)
}

.profile-color-modes-toggle-thumb {
    position: absolute;
    top: -2px;
    left: -2px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background-color: var(--color-profile-color-modes-toggle-thumb-bg);
    transition: transform .3s cubic-bezier(.4,.03,0,1);
    cursor: pointer
}

[data-color-mode=dark] .profile-color-modes-toggle-thumb {
    transform: translateX(18px)
}

.profile-color-modes-popover {
    opacity: .01;
    transition: opacity .5s cubic-bezier(.4,.03,0,1)
}

.profile-color-modes-popover.shown {
    opacity: 1
}

.profile-color-modes-illu-group {
    stroke: var(--color-auto-gray-3)
}

.profile-color-modes-illu-frame {
    opacity: 0
}

:root .profile-color-modes-illu-frame:nth-child(8),[data-color-mode=light] .profile-color-modes-illu-frame:nth-child(8) {
    animation: profile-light-color-modes-illu-anim-frame-show 0s forwards,profile-light-color-modes-illu-anim-frame-hide 0s .3s forwards
}

:root .profile-color-modes-illu-frame:nth-child(9),[data-color-mode=light] .profile-color-modes-illu-frame:nth-child(9) {
    animation: profile-light-color-modes-illu-anim-frame-show 0s .3s forwards,profile-light-color-modes-illu-anim-frame-hide 0s .36s forwards
}

:root .profile-color-modes-illu-frame:nth-child(10),[data-color-mode=light] .profile-color-modes-illu-frame:nth-child(10) {
    animation: profile-light-color-modes-illu-anim-frame-show 0s .36s forwards
}

@keyframes profile-light-color-modes-illu-anim-frame-show {
    0% {
        opacity: 0;
        animation-timing-function: ease-out
    }

    to {
        opacity: 1
    }
}

@keyframes profile-light-color-modes-illu-anim-frame-hide {
    0% {
        opacity: 1;
        animation-timing-function: ease-in
    }

    to {
        opacity: 0
    }
}

[data-color-mode=dark] .profile-color-modes-illu-red {
    stroke: var(--color-scale-red-5)
}

[data-color-mode=dark] .profile-color-modes-illu-orange {
    stroke: var(--color-scale-orange-3)
}

[data-color-mode=dark] .profile-color-modes-illu-purple {
    stroke: var(--color-scale-purple-5)
}

[data-color-mode=dark] .profile-color-modes-illu-green {
    stroke: var(--color-scale-green-3)
}

[data-color-mode=dark] .profile-color-modes-illu-blue {
    stroke: var(--color-scale-blue-4)
}

[data-color-mode=dark] .profile-color-modes-illu-group {
    animation: profile-color-modes-illu-anim .2s cubic-bezier(.72,.08,1,.68) backwards
}

@keyframes profile-color-modes-illu-anim {
    0% {
        stroke: var(--color-scale-gray-6)
    }
}

[data-color-mode=dark] .profile-color-modes-illu-frame {
    animation: profile-color-modes-illu-anim-frame-show 0s forwards,profile-color-modes-illu-anim-frame-hide 0s forwards
}

[data-color-mode=dark] .profile-color-modes-illu-frame:first-child {
    opacity: 1;
    animation: profile-color-modes-illu-anim-frame-hide 0s forwards
}

[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(8) {
    animation: profile-color-modes-illu-anim-frame-show 0s forwards
}

@keyframes profile-color-modes-illu-anim-frame-show {
    0% {
        opacity: 0;
        animation-timing-function: ease-out
    }

    to {
        opacity: 1
    }
}

@keyframes profile-color-modes-illu-anim-frame-hide {
    0% {
        opacity: 1;
        animation-timing-function: ease-in
    }

    to {
        opacity: 0
    }
}

[data-color-mode=dark] .profile-color-modes-illu-red {
    animation-delay: .4s;
    animation-duration: .1s
}

[data-color-mode=dark] .profile-color-modes-illu-orange {
    animation-delay: .5s;
    animation-duration: .1s
}

[data-color-mode=dark] .profile-color-modes-illu-purple {
    animation-delay: .6s;
    animation-duration: .1s
}

[data-color-mode=dark] .profile-color-modes-illu-blue {
    animation-delay: .7s;
    animation-duration: .1s
}

[data-color-mode=dark] .profile-color-modes-illu-green {
    animation-delay: .8s;
    animation-duration: .2s;
    animation-timing-function: cubic-bezier(.47,2.92,.84,-1.5)
}

[data-color-mode=dark] .profile-color-modes-illu-frame:first-child {
    animation-delay: 1.8s
}

[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(2) {
    animation-delay: 1.8s,2.58s
}

[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(3) {
    animation-delay: 2.58s,2.66s
}

[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(4) {
    animation-delay: 2.66s,2.78s
}

[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(5) {
    animation-delay: 2.78s,2.84s
}

[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(6) {
    animation-delay: 2.84s,3.44s
}

[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(7) {
    animation-delay: 3.44s,3.56s
}

[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(8) {
    animation-delay: 3.56s
}

[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(9),[data-color-mode=dark] .profile-color-modes-illu-frame:nth-child(10) {
    animation: none
}

/* 暗夜end */

切换控制是通过修改您的 html 根节点来控制的,因此需要修改您的 html 根节点代码:

代码语言:javascript复制
<html lang="en">
//改为:
<html lang="en" data-color-mode="light">

js

代码语言:javascript复制
// 切换按钮
function set_mode_toggle(e) {
    let t = !0, mode = "dark";
    "true" === e.getAttribute("aria-checked") && (t = !1 , mode = "light")
        e.setAttribute("aria-checked", String(t))
        change_mode(mode);
}
// 改变模式 并设置 cookie
function change_mode(e) {
    const t = document.querySelector("html[data-color-mode]");
    if (e === "dark") document.cookie = "night=1;path=/";
    else document.cookie = "night=0;path=/"
    t && t.setAttribute("data-color-mode", e)
}
// 获取当前模式
function get_user_scheme_mode() {
    const e = document.querySelector("html[data-color-mode]");
    if (!e)
        return;
    const t = e.getAttribute("data-color-mode");
    return "auto" === t ? function() {
        if (get_sys_scheme_mode("dark"))
            return "dark";
        if (get_sys_scheme_mode("light"))
            return "light";
    }() : t
}
// 获取系统模式 先判断 cookie 在获取系统的
function get_sys_scheme_mode(e) {
    let night = document.cookie.replace(/(?:(?:^|.*;s*)nights*=s*([^;]*).*$)|^.*$/, "$1")
    if (night){
        if(night === '0'){
            return false
        }else if(night === '1'){
            return true
        }
    }else
    return window.matchMedia && window.matchMedia(`(prefers-color-scheme: ${e})`).matches
}
!async function() {
    const e = document.querySelector(".js-promo-color-modes-toggle");
    if (e && "auto" === function() {
        const e = document.querySelector("html[data-color-mode]");
        if (!e)
            return;
        return e.getAttribute("data-color-mode")
    }()) {
        "dark" === get_user_scheme_mode() && e.setAttribute("aria-checked", "true")
    }
}()
!async function() {
    document.querySelector(".js-color-mode-settings") && window.history.replaceState({}, document.title, document.URL.split("?")[0])
}()
// 添加点击事件
let toggle_btn = document.getElementsByClassName("js-promo-color-modes-toggle")
toggle_btn[0]? toggle_btn[0].addEventListener('click',function (e) {
    set_mode_toggle(e.currentTarget)
},false):false

0 人点赞