CSS渐变设计指南

news2024/9/20 1:28:13

CSS渐变设计指南

  • 背景渐变
  • 文字渐变
  • SVG渐变


背景渐变

  • 开发界面时,渐变的图像会相比固定颜色的图形更加富有层次感与有趣。使用CSS可以轻松地为文本添加渐变效果。

  • 实现CSS背景色渐变,可以使用CSS3的 background-image 属性结合 linear-gradient() 函数。

  • linear-gradient()函数用于CSS中定义一个沿着直线方向变化的渐变颜色。其基本语法如下:

linear-gradient([<angle> || <side-or-corner>,] <color-stop>[, <color-stop>]+)
  • 参数解释:

    • <angle>:可选参数,定义了渐变线的方向。角度是从元素的上边缘开始顺时针测量的。例如,90deg 表示从左到右的水平线。
    • <side-or-corner>:也可以代替角度来指定渐变的方向。可以是 top, bottom, left, right 或它们的组合(如 top left)来确定渐变线的起点。
    • <color-stop>:必需参数,由一个颜色值加上一个可选的位置组成,位置可以是百分比或者长度值。多个颜色停止点定义了颜色如何过渡。第一个颜色停止点默认从0%开始,最后一个到100%,除非指定了具体位置。

例如:

background-image: linear-gradient(45deg, red, yellow);
/* 从红色渐变到黄色,渐变线从左上角到右下角 */

background-image: linear-gradient(to bottom right, blue, transparent);
/* 从蓝色渐变到透明,渐变线从左上角到右下角 */

background-image: linear-gradient(0deg, green 0%, green 50%, yellow 50%, yellow 100%);
/* 从绿色渐变到黄色,中间有颜色过渡的明确位置 */

通过调整linear-gradient()的不同参数,可以创造出各种视觉效果,使网页设计更加丰富多样。

  • 原始颜色:
    在这里插入图片描述

  • 渐变色效果:

在这里插入图片描述

  • 示例代码:
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Gradient Background</title>
  <style>
    body {
      display: flex;
      justify-content: center;
      align-items: center;
      height: 100vh;
      margin: 0;
    }

    .gradient-box {
      width: 300px;
      height: 300px;
      background-image: linear-gradient(98.87deg, #24cd4d 0%, #00e9b4 100%);
    }
  </style>
</head>

<body>
  <div class="gradient-box"></div>
</body>

</html>

文字渐变

  • 文字渐变可以通过CSS的 background-cliplinear-gradient 属性来实现。
  • 原始颜色:
    在这里插入图片描述
  • 渐变色效果:
    在这里插入图片描述
  • 示例代码:
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .gradient-text {
      font-size: 48px;
      font-weight: bold;
      /* Safari 和 Chrome */
      -webkit-background-clip: text;
      /* 标准属性 */
      background-clip: text;
      /* Safari 和 Chrome */
      -webkit-text-fill-color: transparent;
      /* 标准属性 */
      color: transparent;
      background-image: linear-gradient(98.87deg, #24cd4d 0%, #00e9b4 100%);
    }
  </style>
</head>

<body>
  <p class="gradient-text">Hello, World!</p>
</body>

</html>

background-image: 定义了从左到右的线性渐变背景颜色。
-webkit-background-clip: text;background-clip: text;: 这个属性将背景裁剪到文本本身,而不是其容器。
-webkit-text-fill-color: transparent;color: transparent;: 这些属性使文本的颜色变为透明,以便显示背景渐变。

  • 样式中的 -webkit- 前缀是用于浏览器兼容性的,它们主要针对 Safari 和早期版本的 Chrome。标准的 background-clip 和 color 属性用于支持这些特性的其他现代浏览器。

SVG渐变

  • 背景色和文本的渐变是比较容易实现的,但是svg却不一样。

  • 如果是静态的svg图标可以直接使用已经设置好的渐变,但是在实际开发过程中,可能
    需要去修改svg的颜色,让图标在渐变色(选中状态)和单色(未选中状态)之间来回切换。

  • 首先需要知道svg代码中 <defs> 标签的作用域是整个文档流,这意味着在一个SVG文档中定义的任何 <defs> 内容都可以在整个文档中被引用,而不局限于定义它的SVG节点。这种设计使得 <defs> 成为一种非常灵活的方式来复用图形元素,如渐变、图案等。

  • 当在SVG元素中引用 <defs> 中定义的内容时,通常使用 url() 函数和ID来创建URI引用。

    • 例如,fill: url(#my-gradient) 表示引用ID为 my-gradient 的渐变定义。
  • SVG文档有自己的命名空间,所以 <defs> 中定义的内容可以通过URI引用在整个SVG文档中访问。

  • 即使在同一个HTML文档中有多个 <svg> 节点,只要这些 <svg> 节点在同一个HTML文档流中,它们就可以引用相同的 <defs> 内容。

    • 这意味着可以在一个 <svg> 节点内定义渐变,然后在另一个 <svg> 节点内使用这个渐变。
  • 原始颜色:

在这里插入图片描述

  • 渐变色效果:

在这里插入图片描述

  • 示例代码:
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Gradient Background</title>
  <style>
    body {
      display: flex;
      justify-content: center;
      align-items: center;
      height: 100vh;
      margin: 0;
    }


    .gesture {
      fill: url(#gestureGradient);
    }
  </style>
</head>

<body>
  <svg width='0' height='0'>
    <defs xmlns='<http://www.w3.org/2000/svg>'>
      <linearGradient y2='0' x2='1' y1='1' x1='1' id='gestureGradient' gradientTransform='rotate(25)'>
        <stop stop-color='#27C94E' offset='0' />
        <stop stop-color='#00E98C' offset='1' />
      </linearGradient>
    </defs>
  </svg>
  <svg class="gesture" width='20' height='23' viewBox='0 0 20 23' xmlns='http://www.w3.org/2000/svg'>
    <path
      d='M10.4486 0.922363C9.69114 0.922363 9.06633 1.5155 9.02697 2.27192L8.71247 8.31443C8.7016 8.52341 8.40386 8.55059 8.35532 8.34703L7.41741 4.41346C7.249 3.70711 6.57745 3.23733 5.85653 3.32154C5.07328 3.41303 4.51502 4.12185 4.60963 4.90474L5.51022 12.3568C5.53105 12.5291 5.32106 12.6293 5.20027 12.5047L3.38953 10.6364C2.86039 10.0904 2.0124 10.0112 1.39135 10.4498C0.725529 10.92 0.540273 11.827 0.968363 12.5207L4.85581 18.8196C6.03399 20.7287 8.05952 21.9534 10.2974 22.1099C13.7683 22.3526 16.8859 19.9969 17.6003 16.5917L17.8311 15.4917L19.3503 9.01536C19.5168 8.30546 19.0763 7.59741 18.3655 7.43242C17.7529 7.29025 17.1229 7.59786 16.8581 8.16839L15.8208 10.403C15.7316 10.5952 15.4416 10.5043 15.478 10.2956L16.3154 5.49914C16.4511 4.72208 15.9309 3.98356 15.1535 3.8496C14.4381 3.72631 13.7428 4.15915 13.5374 4.85569L12.5343 8.25782C12.4766 8.45326 12.1902 8.41948 12.1796 8.216L11.8702 2.27192C11.8308 1.51549 11.206 0.922363 10.4486 0.922363Z' />
  </svg>
</body>

</html>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

智谱清影 -CogVideoX-2b-部署与使用,带你揭秘生成6s视频的极致体验!

文章目录 1 效果展示2 CogVideoX 前世今生3 CogVideoX 部署实践流程3.1 创建丹摩实例3.2 配置环境和依赖3.3 模型与配置文件3.4 运行4 遇到问题 1 效果展示 A street artist, clad in a worn-out denim jacket and a colorful bandana, stands before a vast concrete wall in …

JavaScript基础学习:预解析机制

JavaScript基础学习&#xff1a;预解析机制 前言 在 JavaScript 的世界里&#xff0c;代码的执行并不是简单地从上到下按顺序进行的。 在实际执行之前&#xff0c;JavaScript 引擎会进行一个特殊的阶段&#xff0c;称为“预解析”。 这一阶段对于理解 JavaScript 的行为至关…

2025武汉国际半导体产业与电子技术博览会

时间&#xff1a;2025年5月14日-16日地点&#xff1a;武汉中国光谷科技会展中心 展会简介&#xff1a; 为了推动中西部地区电子信息产业的跨越式发展&#xff0c;促进先进技术在中西部地区的创新应用&#xff0c;由中国光电子发展大会组委会联合沃森展览共同打造的2025 武汉国…

网络安全 DVWA通关指南 DVWA Stored Cross Site Scripting (存储型 XSS)

DVWA Stored Cross Site Scripting (存储型 XSS) 文章目录 DVWA Stored Cross Site Scripting (存储型 XSS)XSS跨站原理存储型 LowMediumHighImpossible 参考文献 WEB 安全靶场通关指南 XSS跨站原理 当应用程序发送给浏览器的页面中包含用户提交的数据&#xff0c;但没有经过适…

Yocto - 使用Yocto开发嵌入式Linux系统_01 前言

Embedded Linux Development Using Yocto Project: Leverage the power of the Yocto Project to build efficient Linux-based products, Third Edition By: Otavio Salvador, Daiane Angolini Overview of this book Yocto 项目是开发可靠的嵌入式 Linux 项目的行业标准。与…

C++ | Leetcode C++题解之第405题数字转换为十六进制数

题目&#xff1a; 题解&#xff1a; class Solution { public:string toHex(int num) {if (num 0) {return "0";}string sb;for (int i 7; i > 0; i --) {int val (num >> (4 * i)) & 0xf;if (sb.length() > 0 || val > 0) {char digit val …

内存管理(C++版)

C/C内存分布 程序经过编译生成可执行的二进制程序&#xff0c;我们可以把虚拟进程地址分为以下四个空间&#xff1a;栈&#xff0c;堆&#xff0c;常量区&#xff0c;静态区。这四个区里面存贮的也是不一样的内容。 各个区域所存储内容的说明 栈/堆栈&#xff1a;用于建立函…

C++—string类接口与用法大总结(其中涉及STL基础)

目录 1.string类的本质 2.string类的构造 1.普通构造 2.功能型构造 1.拷贝构造功能型 2.带参构造功能型 3.其余构造 3.operator[] 4.迭代器&#xff08;iterator&#xff09; 1.概念 2.改变string对象本身 3.正向迭代器&#xff08;iterator&#xff09; 4.反向迭代…

基于springboot的驾校预约管理系统的设计与实现 (含源码+sql+视频导入教程)

&#x1f449;文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 基于springboot的驾校预约管理系统5拥有三种角色&#xff1a;管理员、教练、学员 管理员&#xff1a;学员管理、教练管理、车辆管理、车辆关联、维修管理等 教练&#xff1a;学员查看/毕…

通过Python代码发送量化交易信号邮件通知

量化交易利用数学模型和计算机算法来分析市场数据,并生成交易信号,本文将介绍如何使用Python编写一个简单的脚本,通过发送邮件通知量化交易信号。 开启SMTP服务 首先要在发件箱的邮件设置中,将POP3/SMPT服务开启,记录下授权密码,在本地可通过此密码登录,注意有效期和保…

总结拓展十:SAP开发计划(下)

第一节 接口功能开发说明书设计 1、软件系统接口作用 答&#xff1a;系统接口&#xff0c;是实现系统间数据传输的功能。 2、软件系统接口特点 1&#xff09;采用Web Service技术作为平台&#xff0c;有众多的数据传输协议标准&#xff0c;通过API与外界交流数据。 2&…

向上转移和向下转型

向上转型 实际就是创建一个子类对象&#xff0c;将其当成父类对象来使用。格式&#xff1a;父类类型 对象名new 子类类型&#xff08;&#xff09;&#xff1b;eg&#xff1a;Animal animalnew Cat&#xff08;&#xff09;&#xff1b;animal是父类类型&#xff0c;但可以引用…

超详细超实用!!!零基础java开发之云风笔记接口开发之查询单条笔记详细信息(十二)

云风网 云风笔记 云风知识库 一、service/NoteApi新增getNodeDetail接口定义 public interface NoteApi {...NoteManage getNoteDetail(int id); }二、service/impl/NoteServiceImpl接口实现逻辑 public class NoteServiceImpl implements NoteApi {AutowiredNoteMapper not…

产品经理入门攻略:如何从零开始成为产品经理

“人人都是产品经理”这句话相信你一定听过。 作为现在的热门职业&#xff0c;许多朋友也在心里埋下了一颗想要成为产品经理的种子。 产品经理的工作其实没有传说中的那么“高大上”&#xff0c;甚至可以说大多数时候是枯燥且无聊的&#xff0c;需要不断地对数据进行分析&…

如何在ONLYOFFICE文档中,将新插件添加为选项卡

随着 ONLYOFFICE 文档8.1版本的推出&#xff0c;我们引入了各式各样的功能&#xff0c;旨在增强软件功能性和优化用户体验。其中一项改进是&#xff0c;插件可以显示在一个独立的选项卡中了。在本博客文章中&#xff0c;我们将带您了解充分利用这一新功能的各项步骤。 关于 ONL…

图像修复(Inpainting)技术的前沿模型与数据集资源汇总

图像修复&#xff08;Image Inpainting&#xff09;是一种计算机视觉技术&#xff0c;旨在填补图像中的缺失区域或去除图像中的不需要部分&#xff0c;使其看起来自然且无明显痕迹。其目标是根据图像的上下文信息和周围像素来推断和重建缺失区域的内容&#xff0c;以生成逼真且…

实战17-NavBar+Vip布局

NavBar.ets import { PADDING } from ../../constants/size import rvp from ../../utils/resposive/rvIndexComponent export default struct NavBar {StorageProp(topHeight) topHeight: number 0;build() {Row() {Row({ space: rvp(6) }) {Text(请选择地址).fontSize(rvp(1…

Java基础笔记1】Java基础语法

目录 一、Java简介 二、JDK和Java初体验 三、配置环境变量 四、IDEA快捷键 五、Java语法基础 1. 注释 2. 字面量 3. 变量 4. 关键字和标识符 5. 变量详解 a. 数值数据在计算机中的存储​编辑 b. 文本、图片、音频等数据在计算机中的存储 c. 八进制和十六进制 6. 数据类型 a. …

【LabVIEW】事件结构的用法

本篇文章记录我学习LabVIEW的事件结构用法&#xff0c;希望我的分享对你有所帮助&#xff01; 目录 一、案例说明 1、 LabVIEW实现“YAXBXC的计算” 2、添加事件结构 一、案例说明 在LabVIEW实现“YAXBXC的计算”的基础上&#xff0c;加上事件结构&#xff0c;实现单击一次按…