当前位置: 首页 > article >正文

CSS3 渐变、阴影和遮罩的使用

全文目录:

    • 开篇语
      • **前言**
      • **1. CSS3 渐变 (Gradient)**
        • **1.1 线性渐变 (linear-gradient)**
        • **1.2 径向渐变 (radial-gradient)**
      • **2. CSS3 阴影 (Shadow)**
        • **2.1 盒子阴影 (box-shadow)**
        • **2.2 文本阴影 (text-shadow)**
      • **3. CSS3 遮罩 (Mask)**
        • **3.1 基本遮罩 (mask-image)**
        • **3.2 遮罩其他属性**
        • **3.3 支持的浏览器和前缀**
      • **总结**
    • 文末

开篇语

哈喽,各位小伙伴们,你们好呀,我是喵手。运营社区:C站/掘金/腾讯云/阿里云/华为云/51CTO;欢迎大家常来逛逛

  今天我要给大家分享一些自己日常学习到的一些知识点,并以文字的形式跟大家一起交流,互相学习,一个人虽可以走的更快,但一群人可以走的更远。

  我是一名后端开发爱好者,工作日常接触到最多的就是Java语言啦,所以我都尽量抽业余时间把自己所学到所会的,通过文章的形式进行输出,希望以这种方式帮助到更多的初学者或者想入门的小伙伴们,同时也能对自己的技术进行沉淀,加以复盘,查缺补漏。

小伙伴们在批阅的过程中,如果觉得文章不错,欢迎点赞、收藏、关注哦。三连即是对作者我写作道路上最好的鼓励与支持!

前言

CSS3 提供了丰富的视觉效果,包括渐变(gradient)、阴影(shadow)和遮罩(mask)等功能,可以极大地增强网页的视觉表现力。在现代Web设计中,这些技术被广泛应用来实现高质量的用户界面。

1. CSS3 渐变 (Gradient)

渐变是指颜色在一段区域内逐渐变化,通常用于背景、按钮等元素的装饰。CSS3 支持线性渐变(linear-gradient)和径向渐变(radial-gradient)两种常见的渐变方式。

1.1 线性渐变 (linear-gradient)

线性渐变从一个方向上渐变颜色,可以指定渐变的角度或者方向。

基本语法

background: linear-gradient(direction, color1, color2, ...);
  • direction:渐变的方向,可以是角度或方向关键词(如to leftto bottom等)。
  • color1, color2:渐变的颜色,可以指定多个颜色。

例子

/* 从上到下的线性渐变 */
background: linear-gradient(to bottom, #ff7e5f, #feb47b);/* 从左上角到右下角的线性渐变 */
background: linear-gradient(45deg, #ff7e5f, #feb47b);/* 多个颜色的渐变 */
background: linear-gradient(to right, #ff7e5f, #feb47b, #6a82fb);
1.2 径向渐变 (radial-gradient)

径向渐变是从中心向外逐渐变化的颜色。

基本语法

background: radial-gradient(shape size at position, color1, color2, ...);
  • shape:渐变的形状,可以是circle(圆形)或ellipse(椭圆形)。
  • size:定义渐变的大小,如closest-sidefarthest-corner等。
  • position:渐变的起始位置(默认为中心center)。
  • color1, color2:渐变的颜色。

例子

/* 从中心向外的圆形径向渐变 */
background: radial-gradient(circle, #ff7e5f, #feb47b);/* 从顶部左侧的椭圆形渐变 */
background: radial-gradient(ellipse at top left, #ff7e5f, #feb47b);

2. CSS3 阴影 (Shadow)

阴影效果可以让元素在视觉上浮动,增加深度感。CSS3 提供了 box-shadow(盒子阴影)和 text-shadow(文本阴影)两种阴影效果。

2.1 盒子阴影 (box-shadow)

box-shadow 属性为元素添加阴影效果。

基本语法

box-shadow: h-offset v-offset blur-radius spread-radius color inset;
  • h-offset:阴影水平偏移(正值表示向右偏移,负值表示向左偏移)。
  • v-offset:阴影垂直偏移(正值表示向下偏移,负值表示向上偏移)。
  • blur-radius:阴影的模糊半径,值越大阴影越模糊。
  • spread-radius:阴影的扩展半径,值为正时阴影会扩展,值为负时阴影会收缩。
  • color:阴影的颜色,可以是任何合法的颜色值。
  • inset:如果使用inset,阴影会被绘制在元素的内部,而不是外部。

例子

/* 简单的阴影 */
box-shadow: 10px 10px 15px rgba(0, 0, 0, 0.3);/* 多重阴影 */
box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.2), -5px -5px 10px rgba(0, 0, 0, 0.2);/* 内阴影 */
box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.5);
2.2 文本阴影 (text-shadow)

text-shadow 属性为文本添加阴影效果。

基本语法

text-shadow: h-offset v-offset blur-radius color;
  • h-offset:阴影的水平偏移。
  • v-offset:阴影的垂直偏移。
  • blur-radius:阴影的模糊半径。
  • color:阴影的颜色。

例子

/* 简单文本阴影 */
text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);/* 多重文本阴影 */
text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3), -2px -2px 5px rgba(255, 255, 255, 0.3);

3. CSS3 遮罩 (Mask)

遮罩允许你控制元素的透明度、形状和渐变,从而创建复杂的视觉效果。CSS3 的 mask 属性可以通过图片、渐变等方式创建遮罩。

3.1 基本遮罩 (mask-image)

mask-image 属性指定用作遮罩的图片或渐变。

基本语法

mask-image: url('mask.png');
  • url('mask.png'):指定一个图像作为遮罩。图像中的透明部分会显示背景,而不透明部分会隐藏。

例子

/* 使用图片遮罩 */
.element {mask-image: url('mask.png');-webkit-mask-image: url('mask.png'); /* 兼容旧版浏览器 */
}/* 使用渐变遮罩 */
.element {mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 1));
}
3.2 遮罩其他属性
  • mask-size:设置遮罩图片的大小。
  • mask-repeat:控制遮罩图片是否平铺。
  • mask-position:设置遮罩图片的位置。

例子

/* 使用遮罩和渐变结合 */
.element {mask-image: radial-gradient(circle, rgba(0, 0, 0, 1) 40%, rgba(0, 0, 0, 0) 70%);-webkit-mask-image: radial-gradient(circle, rgba(0, 0, 0, 1) 40%, rgba(0, 0, 0, 0) 70%);
}
3.3 支持的浏览器和前缀

mask-image 和其他相关属性在不同的浏览器中有不同的支持情况。为了确保兼容性,可能需要使用 -webkit- 前缀。


总结

  • 渐变:CSS3 渐变是通过 linear-gradientradial-gradient 属性来创建的,支持线性和径向渐变。
  • 阴影:通过 box-shadowtext-shadow 可以给元素或文本添加阴影效果。
  • 遮罩:CSS3 的 mask 属性允许通过图像或渐变来为元素应用遮罩效果。

这些CSS3特性可以大大增强网页的视觉效果,使得设计更加现代化和富有动感。使用这些效果时,确保考虑到兼容性和性能,尤其是在移动设备和低性能设备上。

… …

文末

好啦,以上就是我这期的全部内容,如果有任何疑问,欢迎下方留言哦,咱们下期见。

… …

学习不分先后,知识不分多少;事无巨细,当以虚心求教;三人行,必有我师焉!!!

wished for you successed !!!


⭐️若喜欢我,就请关注我叭。

⭐️若对您有用,就请点赞叭。
⭐️若有疑问,就请评论留言告诉我叭。


版权声明:本文由作者原创,转载请注明出处,谢谢支持!

相关文章:

CSS3 渐变、阴影和遮罩的使用

全文目录: 开篇语**前言****1. CSS3 渐变 (Gradient)****1.1 线性渐变 (linear-gradient)****1.2 径向渐变 (radial-gradient)** **2. CSS3 阴影 (Shadow)****2.1 盒子阴影 (box-shadow)****2.2 文本阴影 (text-shadow)** **3. CSS3 遮罩 (Mask)****3.1 基本遮罩 (m…...

Spring Boot 全局配置文件优先级

好的,Spring Boot的全局配置文件优先级是一个非常重要的概念,它决定了在不同位置的同名配置属性以哪个为准。 Spring Boot 全局配置文件优先级核心知识点 📌 文件格式优先级: 在同一目录下,如果同时存在 application.properties 和…...

流媒体基础解析:视频清晰度的关键因素

在视频处理的过程中,编码解码及码率是影响视频清晰度的关键因素。今天,我们将深入探讨这些概念,并解析它们如何共同作用于视频质量。 编码解码概述 编码,简单来说,就是压缩。视频编码的目的是将原始视频数据压缩成较…...

grid网格布局

使用flex布局的痛点 如果使用justify-content: space-between;让子元素两端对齐,自动分配中间间距,假设一行4个,如果每一行都是4的倍数那没任何问题,但如果最后一行是2、3个的时候就会出现下面的状况: /* flex布局 两…...

C#数字金额转中文大写金额:代码解析

C#数字金额转中文大写金额:代码解析 在金融相关的业务场景中,我们常常需要将数字金额转换为中文大写金额,以避免金额被篡改,增加金额的准确性和安全性。本文将深入解析一段 C# 代码,这段代码通过巧妙的设计&#xff0…...

Vehicle HAL(2)--Vehicle HAL 的启动

目录 1. VehicleService-main 函数分析 2. 构建EmulatedVehicleHal 2.1 EmulatedVehicleHal::EmulatedVehicleHal(xxx) 2.2 EmulatedVehicleHal::initStaticConfig() 2.3 EmulatedVehicleHal::onPropertyValue() 3. 构建VehicleEmulator 4. 构建VehicleHalManager (1)初…...

JS中的函数防抖和节流:提升性能的关键技术

在JavaScript开发中,函数防抖和节流是两种常用的优化技术,用于处理那些可能会被频繁触发的事件,如resize、scroll、mousemove等。本文将详细介绍函数防抖和节流的概念、实现方法以及它们之间的区别。 一、什么是函数防抖和节流? …...

Android Compose开发架构选择指南:单Activity vs 多Activity

简介 掌握Jetpack Compose的Activity架构选择,是构建高性能、易维护Android应用的关键一步。在2025年的Android开发领域,随着Jetpack Compose的成熟和Android系统对多窗口模式的支持,开发者面临架构选择时需要更加全面地考虑各种因素。本文将深入探讨单Activity架构和多Act…...

【Netty系列】Reactor 模式 1

目录 一、Reactor 模式的核心思想 二、Netty 中的 Reactor 模式实现 1. 服务端代码示例 2. 处理请求的 Handler 三、运行流程解析(结合 Reactor 模式) 四、关键点说明 五、与传统模型的对比 六、总结 Reactor 模式是 Netty 高性能的核心设计思想…...

vue3 el-input type=“textarea“ 字体样式 及高度设置

在Vue 3中&#xff0c;如果你使用的是Element Plus库中的<el-input>组件作为文本域&#xff08;type"textarea"&#xff09;&#xff0c;你可以通过几种方式来设置字体样式和高度。 1. 直接在<el-input>组件上使用style属性 你可以直接在<el-input&…...

并发解析hea,转为pdf格式

由于每次解析一个heap需要时间有点久&#xff0c;就写了一个自动解析程pdf的一个脚本。 down_lib.sh是需要自己写的哦&#xff0c;主要是用于下载自己所需程序的库&#xff0c;用于解析heap。 #!/bin/bash# 优化版通用解析脚本&#xff08;并发加速&#xff09;&#xff1a;批…...

【C语言】详解 指针

前言&#xff1a; 在学习指针前&#xff0c;通过比喻的方法&#xff0c;让大家知道指针的作用。 想象一下&#xff0c;你在一栋巨大的图书馆里找一本书。如果没有书架编号和目录&#xff0c;这几乎是不可能完成的任务。 在 C 语言中&#xff0c;指针就像是图书馆的索引系统&…...

RabbitMQ仲裁队列高可用架构解析

#作者&#xff1a;闫乾苓 文章目录 概述工作原理1.节点之间的交互2.消息复制3.共识机制4.选举领导者5.消息持久化6.自动故障转移 集群环境节点管理仲裁队列增加集群节点重新平衡仲裁队列leader所在节点仲裁队列减少集群节点 副本管理add_member 在给定节点上添加仲裁队列成员&…...

刚出炉热乎的。UniApp X 封装 uni.request

HBuilder X v4.66 当前最新版本 由于 uniapp x 使用的是自己包装的 ts 语言 uts。目前语言还没有稳定下来&#xff0c;各种不支持 ts 各种报错各种不兼容问题。我一个个问题调通的&#xff0c;代码如下&#xff1a; 封装方法 // my-app/utils/request.uts const UNI_APP_BASE…...

Apache Kafka 实现原理深度解析:生产、存储与消费全流程

Apache Kafka 实现原理深度解析&#xff1a;生产、存储与消费全流程 引言 Apache Kafka 作为分布式流处理平台的核心&#xff0c;其高吞吐、低延迟、持久化存储的设计使其成为现代数据管道的事实标准。本文将从消息生产、持久化存储、消息消费三个阶段拆解 Kafka 的核心实现原…...

Python 训练营打卡 Day 41

简单CNN 一、数据预处理 在图像数据预处理环节&#xff0c;为提升数据多样性&#xff0c;可采用数据增强&#xff08;数据增广&#xff09;策略。该策略通常不改变单次训练的样本总数&#xff0c;而是通过对现有图像进行多样化变换&#xff0c;使每次训练输入的样本呈现更丰富…...

leetcode付费题 353. 贪吃蛇游戏解题思路

贪吃蛇游戏试玩:https://patorjk.com/games/snake/ 问题描述 设计一个贪吃蛇游戏,要求实现以下功能: 初始化游戏:给定网格宽度、高度和食物位置序列移动操作:根据指令(上、下、左、右)移动蛇头规则: 蛇头碰到边界或自身身体时游戏结束(返回-1)吃到食物时蛇身长度增加…...

CCPC dongbei 2025 I

题目链接&#xff1a;https://codeforces.com/gym/105924 题目背景&#xff1a; 给定一个二分图&#xff0c;左图编号 1 ~ n&#xff0c;右图 n 1 ~ 2n&#xff0c;左图的每个城市都会与右图的某个城市犯冲&#xff08;每个城市都只与一个城市犯冲&#xff09;&#xff0c;除…...

系统性学习C语言-第十三讲-深入理解指针(3)

系统性学习C语言-第十三讲-深入理解指针&#xff08;3&#xff09; 1. 数组名的理解2. 使用指针访问数组3. ⼀维数组传参的本质4. 冒泡排序5. ⼆级指针 6. 指针数组7. 指针数组模拟二维数组 1. 数组名的理解 在上⼀个章节我们在使用指针访问数组的内容时&#xff0c;有这样的代…...

代理模式核心概念

代理模式核心概念 代理模式是一种结构型设计模式&#xff0c;通过创建一个代理对象来控制对原始对象的访问。主要分为两类&#xff1a; 一、静态代理 (Static Proxy) 定义&#xff1a;在编译期确定代理关系的模式&#xff0c;代理类和目标类都需要实现相同的接口。 核心特点…...

uni-app学习笔记十五-vue3页面生命周期(二)

onShow&#xff1a;用于监听页面显示&#xff0c;页面每次出现在屏幕上都触发&#xff0c;包括从下级页面点返回露出当前页面&#xff1b; onHide:监听页面隐藏&#xff0c;当离开当前页面时触发。 示例代码&#xff1a; <template><view>姓名&#xff1a;{{nam…...

贪心算法实战篇2

文章目录 前言序列问题摆动序列单调递增的数字 贪心解决股票问题买卖股票的最佳时机II 两个维度权衡问题分发糖果根据身高重建队列 前言 今天继续带大家进行贪心算法的实战篇2&#xff0c;本章注意来解答一些运用贪心算法的中等的问题&#xff0c;大家好好体会&#xff0c;怎么…...

Java 大视界 -- Java 大数据机器学习模型在元宇宙虚拟场景智能交互中的关键技术(239)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…...

Flask中关于app.url_map属性的用法

目录 一、app.url_map 是什么? 二、可以查看哪些信息? 三、示例:打印所有路由 四、结合 url_for() 使用 五、常见用途场景 六、结合 Flask CLI 使用 总结 app.url_map 是 Flask 中非常重要的一个属性,用于查看或操作整个应用的 URL 路由映射表(routing map)。它展…...

高速串行接口

1.网口设计方案 上图中给出了两种网口设计方案&#xff0c;最上面是传统设计方式&#xff0c;下面是利用GT作为PHY层的设计&#xff0c;然后FPGA中设计协议层和MAC层。 2.SRIO SRIO的本地操作和远程操作 3.其他高速接口 srio rapid io aurora8b10b aurora64b66b pcie s…...

学习STC51单片机23(芯片为STC89C52RCRC)

每日一言 成功的路上从不拥挤&#xff0c;因为坚持的人不多&#xff0c;你要做那个例外。 通过单片机发指令给ESP8266进行通信 通信原理(也是接线原理) 代码如下 代码解释一下&#xff0c;因为我们的指令是字符数组&#xff08;c语言没有字符串的概念&#xff09;&#xff0c;…...

一个完整的日志收集方案:Elasticsearch + Logstash + Kibana+Filebeat (一)

整体链路 [应用服务器] --> [Filebeat] --> [Logstash] --> [Elasticsearch] --> [Kibana] 组件职责 Kibana&#xff1a; 可视化和分析日志数据Elasticsearch&#xff1a; 存储和索引日志数据Logstash&#xff1a; 解析、转换和丰富日志数据Filebeat&#xff1a…...

网络系统中安全漏洞扫描为何重要?扫描啥?咋扫描?

在网络系统中&#xff0c;安全漏洞扫描占据着极其重要的位置&#xff0c;这一环节有助于我们发现并消除潜在的安全隐患&#xff0c;进而提高网络安全防护的等级。下面&#xff0c;我将对此进行详尽的说明。 基本概念 漏洞扫描技术可以揭示并评估网站存在的安全风险&#xff0…...

HiveSQL语法全解析与实战指南

Hive SQL完整语法体系与特性解析 一、数据定义语言&#xff08;DDL&#xff09; 库操作 CREATE DATABASE [IF NOT EXISTS] dbname[COMMENT 描述][LOCATION hdfs_path][WITH DBPROPERTIES (keyvalue)];ALTER DATABASE dbname SET DBPROPERTIES (keyvalue); DROP DATABASE [IF…...

【conda报错】InvalidArchiveError

InvalidArchiveError - conda - Conda Community Forum 还是pip安装吧...