前端每日实战:152# 视频演示如何用纯 CSS 创作一个圆点错觉效果

效果预览

按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。

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

可交互视频

此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。

请用 chrome, safari, edge 打开观看。

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

源代码下载

每日前端实战系列的全部源代码请从 github 下载:

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

代码解读

此项目无用户自定义的 dom 元素,利用系统默认的 <body> 元素作为容器。

定义页面尺寸,背景设置为黑色:

body {
    margin: 0;
    width: 100vw;
    height: 100vh;
    background-color: black;
}

用线性渐变画出一横一竖二条灰色的细线:

body {
    margin: 0;
    width: 100vw;
    height: 100vh;
    background-color: black;
    background-image:
        linear-gradient(
            to bottom,
            #555 2vmin,
            transparent 2vmin
        ),
        linear-gradient(
            to right,
            #555 2vmin,
            transparent 2vmin
        );
}

用径向渐变在左上角画一个白色的圆点:

body {
    margin: 0;
    width: 100vw;
    height: 100vh;
    background-color: black;
    background-image:
        radial-gradient(
            circle at 1vmin 1vmin,
            white 1vmin,
            transparent 1vmin
        ),
        linear-gradient(
            to bottom,
            #555 2vmin,
            transparent 2vmin
        ),
        linear-gradient(
            to right,
            #555 2vmin,
            transparent 2vmin
        );
}

平铺背景:

body {
    margin: 0;
    width: 100vw;
    height: 100vh;
    background-color: black;
    background-image:
        radial-gradient(
            circle at 1vmin 1vmin,
            white 1vmin,
            transparent 1vmin
        ),
        linear-gradient(
            to bottom,
            #555 2vmin,
            transparent 2vmin
        ),
        linear-gradient(
            to right,
            #555 2vmin,
            transparent 2vmin
        );
    background-size: 10vmin 10vmin;
}

为避免圆点紧贴在左侧和顶部,为背景增加一点偏移量:

body {
    margin: 0;
    width: 100vw;
    height: 100vh;
    background-color: black;
    background-image:
        radial-gradient(
            circle at 1vmin 1vmin,
            white 1vmin,
            transparent 1vmin
        ),
        linear-gradient(
            to bottom,
            #555 2vmin,
            transparent 2vmin
        ),
        linear-gradient(
            to right,
            #555 2vmin,
            transparent 2vmin
        );
    background-size: 10vmin 10vmin;
    background-position: 5vmin 5vmin;
}

现在,如果视线在页面中移动,就会看到黑色小圆点,这实际上是错觉。

大功告成!

原文地址:https://www.cnblogs.com/baimeishaoxia/p/11832308.html

时间: 2024-11-05 14:57:37

前端每日实战:152# 视频演示如何用纯 CSS 创作一个圆点错觉效果的相关文章

前端每日实战:157# 视频演示如何用纯 CSS 创作一个棋盘错觉动画(实际上每一行都是平行的)

效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/VEyoGj 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, safari, edge 打开观看. https://scrimba.com/p/pEgDAM/cppKmsd 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/f

前端每日实战:99# 视频演示如何用纯 CSS 创作一个过山车 loader

效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/KBxYZg/ 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, safari, edge 打开观看. https://scrimba.com/p/pEgDAM/cagbkSL 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/

前端每日实战:160# 视频演示如何用纯 CSS 创作一个打开内容弹窗的交互动画

效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/GYXvez 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, safari, edge 打开观看. https://scrimba.com/p/pEgDAM/cNzVnAL 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/f

前端每日实战:158# 视频演示如何用纯 CSS 创作一个雨伞 toggle 控件

效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/pxLbjv 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, safari, edge 打开观看. https://scrimba.com/p/pEgDAM/cMV8euJ 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/f

前端每日实战:156# 视频演示如何用纯 CSS 创作一个飞机舷窗风格的 toggle 控件

效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/jeaOrw 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, safari, edge 打开观看. https://scrimba.com/p/pEgDAM/cdZVGSD 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/f

前端每日实战:146# 视频演示如何用纯 CSS 创作一个脉动 loader

效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/wYvGwr 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, safari, edge 打开观看. https://scrimba.com/p/pEgDAM/cnMgQTr 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/f

前端每日实战:135# 视频演示如何用纯 CSS 创作一个悬停时右移的按钮特效

效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/PdaNXw 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, safari, edge 打开观看. https://scrimba.com/p/pEgDAM/c3MV9Sa 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/f

前端每日实战:127# 视频演示如何用纯 CSS 创作一个圆环旋转错觉动画

效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/oPWJNj/ 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, safari, edge 打开观看. https://scrimba.com/p/pEgDAM/cbvPWHM 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/

前端每日实战:47# 视频演示如何用纯 CSS 创作一个蝴蝶标本展示框

效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/xzgZzQ 可交互视频教程 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码. 请用 chrome, safari, edge 打开观看. https://scrimba.com/p/pEgDAM/cN7EncL 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope