53 个 CSS 特效 2

53 个 CSS 特效 2

这里是第 17 到 32 个,跟上一部分比起来多了两个稍微大一点的首页布局,上篇:53 个 CSS 特效 1,依旧,预览地址在 http://www.goldenaarcher.com/html-css-js-proj/,git 地址: https://github.com/GoldenaArcher/html-css-js-proj

  1. 3D Card

    日常用得到,基本逻辑其实上面都实现过挺多次了

    在这里插入图片描述

  2. Helicopter

    和自行车一样,炫技之作,不过背景的移动倒是具有一些参考意义,有些情况下可能会用得到

    在这里插入图片描述

  3. Business Card

    日常……可能用得到……?感觉如果有什么 logo 需要 hover,并且正反内容都不一样的话,确实有可能需要。

    这个技巧比较妙的就是,它是纯 CSS 实现,没用 JS。

    在这里插入图片描述

    card 的特效和之前写的差不多,不过这个最主要的区别还是在于前后卡片内容不同,并且全都由 CSS 控制,这里也学到了一个新的 CSS:

    backface-visibility: hidden;
    

    这样在翻转到反面时(backface),卡片的内容就是隐藏的了。

    没有这个特性的效果如下:

    在这里插入图片描述

    在这里插入图片描述

    这个特性在实现的时候会同时管理前后两面的 visibility,不怎么做 3D 还真的不太了解这些 CSS……

    之前在学黑马的时候也有做过类似的特效:

    区别在于这个这个用了 z-index 去进行控制管理,二者实现上稍稍不太一样,不过同样都挺妙的。

    这个硬币的笔记在:学完一起做个走马灯吧 - CSS 3D 转换学习笔记&学习案例

    里面对于 2D 和 3D 的转换有更多的解释性注释。

    另外一点就是背景的实现,这里用的是 linear-gradient,然后子内容用的是 margin 去控制和边框的距离:

    background: linear-gradient(100deg,rgb(255, 255, 255) 40%,rgb(38, 38, 38) 0
    );
    

    另一种技巧用的是 border

    我个人可能会偏向用 border 去实现……?这样感觉 margin 的过度是不是会更自然……?但是这样的话,姓名那边要做到左边穿模也要另外加一下 border-left 去拼一个三角补全缺口吧……

    上面 border 的笔记:CSS 的十个高级使用技巧

  4. Radio Button

    同 toggle 和 checkbox

    在这里插入图片描述

  5. Slide Show

    在这里插入图片描述

    日常……可能用得到……?

    主要还是看业务需求,如果使用框架,大多数情况下总是能够找到对应的 react/vue/ang 的 slideshow/carousel,二者都是用来寻找这个类似功能的关键词,看怎么命名了,前者叫幻灯片,后者叫轮播,这里指代的就是一个东西

    总体效果有这么几个,因为间隔时间比较多,所以可能看得不是很清楚:

    1. 自动播放
    2. 喜爱暗的按钮可以控制自动播放,点击一下停止转播放或反过来
    3. 点击左右手动翻页停止播放

    CSS 方面这里倒是没有什么特别特殊的技巧,主要还是用 JS 控制 slideshow 的播放和 class 的增删

    我还以为写过好几个 slide show,结果找了一下一个都没看到,这可真是……

  6. Atom Animation

在这里插入图片描述
也是纯 CSS 实现,主要就是 3D+animation 特效的这些事儿,使用场景感觉也有限,不过用来学学 3D 挺好的

另外就是,如果要做正方/正圆,可以定义高度之后使用 aspect-ration: 1; 进行实现

  1. Button

. 在这里插入图片描述

和其他的 UI 功能需求相似

  1. Hamburger Menu2

    日常可能用得到,不过如果使用 UI 库的话有一定概率 navbar 是覆盖内容

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rJZiI0Fx-1692916019760)(img/hamburger2.gif)]

    其实这个效果之前有提到过,这里唯一的区别大概就是多了一个背景放大的过度,以及 menu 不是出现在 sidebar,而是出现在屏幕正中间

    在这里插入图片描述

    这是另一个效果的直观对比,可以看出来 hamburger icon 的效果是一样的,这里的是一个简化版

  2. Sidebar

    日常可能用得到,不过如果使用 UI 库的话有一定概率 sidebar 是覆盖内容

    在这里插入图片描述
    特效大概是这样的

    这里做了几个 breakpoints,主要就是 menu 和背景的大小区别,小屏幕两个都是全屏,大屏幕大概是 55 分,37 分,28 分这样,就不重复放了

    顺便讲几个新学到的 tricks:

    1. 定位

      在这里插入图片描述

      这也算是一个新的 trick 吧,以前都是用 position: absolute 去解决的,这里使用的是 transform: translateX(),也是以前没有考虑过的点

    2. flex-grow

      在这里插入图片描述

      不用 flex-grow: 1 的效果:

      在这里插入图片描述

      flex-grow: 1 会让当前内容,也就是这个 text 的内容填补这个 flex 剩下的所有空间,间接实现了让箭头填充到最右边的功能。

      以前看的免费教程大多数都是比较老的教程,里面 flex 相对而言都是比较新的内容,所以一般都是用 position: absolute 把旁边的 icon 拉出文档流。现在看来使用 flex 的方法代码量更少,实现起来也挺妙的。

    3. flex & margin

      在这里插入图片描述

      使用 margin-left: auto 就会自动的实现左对齐,即等同于 margin-left: 10%

      在这里插入图片描述

      上面是这是不使用 margin-left: auto 的情况。不过就算使用 margin-right: 0,其实也不会将多余的部分 assign 给 margin-left

      同样实现的内容还有父元素使用 padding-left 之类的,总体来说实现方法较多

    这个负载度在这个半成品系列中算是比较高的了,顺便感叹下,在 yt 上刷新的 css 教程果然……还蛮新的……

  3. Flower

    用不太到,但是思路挺有趣的,如果想要更加自然一点的效果,可以不同花瓣使用 z-index 调整一下,或者看看能不能用 pseudo-element 增加点锯齿/大小。当然,本身效果就挺自然的,自然界的花朵同一朵花上的花瓣其实真说起来差异不是特别大

    这还是第一个静态的,效果如下:

    在这里插入图片描述

    其实这里主要还是更深入地了解了一下 ::before::after 的特性,如果直接讲 CSS 作用在 div 上,那么在做 rotate 的时候会将原本的 CSS 也进行修改:

    在这里插入图片描述

    在这里插入图片描述

    但是如果用 ::before::after 的话,那么 ::before::after 上的 CSS 只会随着主 div 上的 css 进行修改,本身变形

    在这里插入图片描述

    堆叠效果玩成后:

    在这里插入图片描述

  4. Navbar

    在这里插入图片描述

    日常可能用得到,思路比较巧妙的 navbar,适用于个人项目或者特质化项目,一般情况下 UI 库应该是会包括这个功能了

  5. Navigation 2

    在这里插入图片描述

    同上

  6. dropdown

    实用性同其他的 UI 组件一样

    在这里插入图片描述

    有个比较有趣的特点就是,这个 dropdown 的视线是二阶段的,它的组成也是通过两部分实现,第一个是白色的背景,第二个才是下拉框的主题:

    在这里插入图片描述

    动画的实现有几个要点:

    • CSS 中,dropdown 主体的高度从 0,hover 时变为 auto 让 CSS 自动计算高度
    • 通过 JS 获取当前下拉框的长度,并将下拉框的值赋给背景
    • 为了实现从有到左的淡入,dropdown 的主题有一个 translateX() 的位移
    • 为了完成延迟渲染的效果,dropdown 本体的 animation 需要有一个 delay 的操作

    这样综合操作就能够完成先显示背景,随后主题内容再滑入的一个特效

    个人来说这样的实现有好有坏,最大的问题就在于会有一个额外的 div 悬浮在空中:

    在这里插入图片描述

    如果验货一方完全不懂技术,这个还是可以操作的,但是如果上一些 automated test 的话,可能会有点问题

  7. navigation

    在这里插入图片描述

    和其他的 nav 差不多,适合个人/特质化项目

    顺便提一下这里用到的挺有趣的一个特性,就是 pointer-events: none,这个 CSS 主要是可以管理鼠标时间,比如说,其实这些 div 都是存在的,只不过 opacity 设置成了 1:

    在这里插入图片描述

    但是上面的动图很明显的可以看到,鼠标经过原本图标所在的地方时,背景变色的动画并没有被触发,这实际上是因为子类所有的 pointer-events,在没有 FOLLOW US 这段话没有被 hover 的时候,是设置成 none,也就是任何鼠标事件都不被触发。当 hover 事件触发后,pointer-events 设置成了自动,那么该元素的鼠标事件才会正常被触发。

    这也是一个相对而言比较新,但是以前没接触过的 CSS3 的知识点。

  8. animated earth

    在这里插入图片描述

    不太常用,这里亮暗地图用的是图片,所以相似的案例反而找图会比较困难。其他方面,CSS 本身不太复杂,主要是几个比较少见的特性运用:

    • clip-path

      https://bennettfeely.com/clippy/

      可以到上面这个网站研究一下想要的形状,这是拖拽式的

    • box-shadow

      这里主要同时应用了外部和内部的,并且内部的 inset 是用了亮色,形成了明暗对比

  9. grid menu

    完成布局后大概这样:

    在这里插入图片描述

    特效:

    在这里插入图片描述

    CSS grid 之前多多少少提过一些,现在这里再复述一下。简单来说就是对于页面的 2D 规划,grid 是有无与伦比的优势的。简单的三行代码就可以实现如下布局:

    在这里插入图片描述

    display: grid;
    grid-template-columns: 2rem 1fr 2rem;
    grid-template-rows: 10rem 1fr 2rem;
    

    对于将内容放置于网格上的操作也很简单,如我想将内容放置于中间最大的那块,只需要选中对应的 div,然后添加代码:

    grid-column: 2/3;
    grid-row: 2/3;
    

    就可以轻松实现效果:

    在这里插入图片描述

    特效部分,这里做的延迟主要就是应用两重 transition,并且使用 delay 做延迟。

    这里也做了 responsive,基本上来说就是要把所有的布局都重写一遍,如:

    在这里插入图片描述

    最后,写到一半突然注意到这个:

    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/108929.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

XSS攻击是怎么回事?记录一下

title: XSS攻击 date: 2023-08-27 19:15:57 tags: [XSS, 网络安全] categories: 网络安全 今天学习了一个网络攻击的手段,XSS攻击技术,大家自建网站的朋友,记得看看是否有此漏洞。 🎈 XSS 攻击 全称跨站脚本攻击 Cross Site Sc…

《机器学习核心技术》分类算法 - 决策树

「作者主页」:士别三日wyx 「作者简介」:CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者 「推荐专栏」:小白零基础《Python入门到精通》 决策树 1、决策树API2、决策时实际应用2.1、获取数据集2.2、划分数据集2.3、决策…

数据库表结构导出为word、html、markdown【转载,已解决,已验证,开源】

注&#xff1a;本文为gitcode代码验证&#xff0c;转载gitcode gitcode&#xff1a;https://gitcode.net/mirrors/pingfangushi/screw?utm_sourcecsdn_github_accelerator 整理数据库文档&#xff1a;https://mp.weixin.qq.com/s/Bo_U5_cl82hfQ6GmRs2vtA <!--数据库文档核…

数据结构--树4.1

目录 一、树的定义 二、结点的分类 三、结点间的关系 四、结点的层次 五、树的存储结构 一、树的定义 树&#xff08;Tree&#xff09;是n&#xff08;n>0&#xff09;个结点的有限集。当n0时称为空树&#xff0c;在任意一个非空树中&#xff1a; ——有且仅有一个特定的…

AI时代,程序员需要焦虑吗?

原文来自 微信公众号"互联网技术人进阶之路". 目录 前言一、程序员会被 AI 取代么&#xff1f;二、服务端开发尚难被 AI 取代三、服务端开发何去何从&#xff1f;四、业界首部体系化、全景式解读服务端开发的著作第一部分&#xff1a;服务端开发的技术和方法第二部分…

nginx-获取客户端IP地址

上有服务器与客户端中间是有nginx代理服务器的&#xff0c;上游服务器如何获取客户端真实ip地址&#xff1f; nginx代理服务器设置X-Forwarded-For的header参数&#xff0c;代理服务器通过remote_addr获取客户端ip地址&#xff0c;将ip地址写入nginx代理服务器的X-Forwarded-Fo…

python编写四画面同时播放swap视频

当代技术让我们能够创建各种有趣和实用的应用程序。在本篇博客中&#xff0c;我们将探索一个基于wxPython和OpenCV的四路视频播放器应用程序。这个应用程序可以同时播放四个视频文件&#xff0c;并将它们显示在一个GUI界面中。 C:\pythoncode\new\smetimeplaymp4.py 准备工作…

sql数据库怎么备份,sql 实时备份

在当今互联网时代&#xff0c;数据已经成为企业的核心资产。然而&#xff0c;数据的安全性和完整性面临硬件问题、软件故障、人工操作错误等各种威胁。为了保证数据的安全&#xff0c;实时备份已经成为公司必须采取的重要措施之一。下面我们就重点介绍SQL实时备份的重要实施方法…

百亿补贴通用H5导航栏方案 | 京东云技术团队

背景 在移动端页面中&#xff0c;由于屏幕空间有限&#xff0c;导航条扮演着非常重要的角色&#xff0c;提供了快速导航到不同页面或功能的方式。用户也通常会在导航条中寻找他们感兴趣的内容&#xff0c;因此导航条的曝光率较高。在这样的背景下&#xff0c;提供一个动态灵活…

你不知道的宝藏合金:高熵合金

高熵合金&#xff08;High-entropy alloys&#xff09;简称HEA&#xff0c;是由五种或五种以上等量或大约等量金属形成的合金。由于高熵合金可能具有许多理想的性质&#xff0c;因此在材料科学及工程上相当受到重视。 传统合金是以1~2种金属为主&#xff0c;并通过添加特定的少…

基于PyTorch深度学习遥感影像地物分类与目标检测、分割及遥感影像问题深度学习优化

我国高分辨率对地观测系统重大专项已全面启动&#xff0c;高空间、高光谱、高时间分辨率和宽地面覆盖于一体的全球天空地一体化立体对地观测网逐步形成&#xff0c;将成为保障国家安全的基础性和战略性资源。未来10年全球每天获取的观测数据将超过10PB&#xff0c;遥感大数据时…

兄弟,王者荣耀的段位排行榜是通过Redis实现的?

目录 一、排行榜设计方案1、数据库直接排序2、王者荣耀好友排行 二、Redis实现计数器1、什么是计数器功能&#xff1f;2、Redis实现计数器的原理&#xff08;1&#xff09;使用INCR命令实现计数器&#xff08;2&#xff09;使用INCRBY命令实现计数器 三、通过Redis实现“王者荣…

Java注解与反射

&#x1f497;wei_shuo的个人主页 &#x1f4ab;wei_shuo的学习社区 &#x1f310;Hello World &#xff01; Java注解与反射 Java注解和反射是Java语言中两个强大的特性&#xff0c;它们可以一起使用以实现动态的、灵活的编程和元数据处理 注解 Java注解&#xff08;Annotatio…

c语言六子棋(Alpha-Beta剪枝算法)

c语言Alpha-Beta剪枝算法六子棋介绍 Alpha-Beta剪枝算法是一种用于优化博弈树搜索的算法&#xff0c;可以在搜索过程中减少不必要的计算&#xff0c;从而提高搜索效率。该算法常用于博弈游戏&#xff0c;如六子棋。 六子棋是一种类似于五子棋的棋类游戏&#xff0c;在一个六边形…

ubuntu20.04 编译安装运行emqx

文章目录 安装依赖编译运行登录dashboard压力测试 安装依赖 Erlang/OTP OTP 24 或 25 版本 apt-get install libncurses5-dev sudo apt-get install erlang如果安装的erlang版本小于24的话&#xff0c;可以使用如下方法自行编译erlang 1.源码获取 wget https://github.com/erla…

【大模型AIGC系列课程 3-2】国产开源大模型:ChatGLM

1. GLM https://arxiv.org/pdf/2103.10360.pdf GLM是General Language Model的缩写,是一种通用的语言模型预训练框架。它的主要目标是通过自回归的空白填充来进行预训练,以解决现有预训练框架在自然语言理解(NLU)、无条件生成和有条件生成等任务中表现不佳的问题。 具体来…

WPF网格拖动自动布局效果

WPF网格拖动自动布局效果 使用Canvas和鼠标相关事件实现如下的效果: XAML代码: <Window x:Class="CanvasTest.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:

java练习8.100m小球落地

题目: 如一个小球从100米高度自由落下&#xff0c;每次落地后就反跳回原高度的一半。 那么求它在第10次落地时&#xff0c;共经过多少米&#xff1f;第10次反弹多高&#xff1f; public static void main(String[] args) {/*假如一个小球从100米高度自由落下&#xff0c;每次落…

按软件开发阶段的角度划分:单元测试、集成测试、系统测试、验收测试

1.单元测试&#xff08;Unit Testing&#xff09; 单元测试&#xff0c;又称模块测试。对软件的组成单位进行测试&#xff0c;其目的是检验软件基本组成单位的正确性。测试的对象是软件里测试的最小单位&#xff1a;模块。 测试阶段&#xff1a;编码后或者编码前&#xff08;…

天润融通「微藤大语言模型平台2.0」以知识驱动企业高速增长

8月23日&#xff0c;天润融通&#xff08;又称“天润云”,2167.HK&#xff09;&#xff0c;正式发布「微藤大语言模型平台2.0」。 “大模型企业知识企业知识工程”。 “不能有效记录和管理知识的企业是不能持续进步的。在企业的生产流程中&#xff0c;相比于其他场景&#xff0…