自定义字体样式引入使用方法、文本阴影、边框阴影、(边框)圆角、渐变、理解重绘与回流、渐进增强和优雅降级的区别

本文主要是介绍自定义字体样式引入使用方法、文本阴影、边框阴影、(边框)圆角、渐变、理解重绘与回流、渐进增强和优雅降级的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1、文本阴影 text-shadow

 2、边框阴影 box-shadow

3、自定义字体样式方法

 引入与使用方法举例:

4、(边框)圆角

5、渐变

6、过渡  transition

7、理论知识:理解重绘(/重排)与回流

8、渐进增强和优雅降级的区别 


1、文本阴影 text-shadow

语法:text-shadow: h-shadow v-shadow blur color;

描述
h-shadow必需,水平阴影的位置,允许负值。
v-shadow必需,垂直阴影的位置,允许负值。
blur可选,模糊的距离
color可选,阴影的颜色

举例:

   /*text-shadow: h-shadow(必需,水平阴影的位置,允许负值 正值阴影在右)v-shadow(必需,垂直阴影的位置) blur(阴影模糊的距离,模糊半径) color;中间用,隔开,可以加多重阴影*/.box {font-size: 50px;text-shadow: 10px 20px 4px yellow,12px 22px 5px green,14px 24px 4px pink;/* 多重阴影 */}

 效果:

举例: 

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title></title><style type="text/css">.box,.box1,.box2 {margin: 0 auto;background-color: #706d6d;width: 433px;height: 200px;font-size: 50px;font-weight: 900;text-align: center;}.box {color: #000000;text-shadow: 0 2px #c5c5c5;}.box1 {color: #FFFFFF;text-shadow: -2px -1px #ADD8E6,-4px -2px #ADD8E6,-6px -3px #ADD8E6,-8px -4px #ADD8E6;}.box2 {color: #FFFFFF;text-shadow: 4px 6px #706d6d,6px 8px #FFFFFF;}</style></head><body><div class="box">称体APPLESTYLEE <br>FFECT</div><div class="box1">3D APPLE STYLE EFFECT</div><div class="box2">假边框 APPLE STYLE EFFECT</div></body>
</html>

效果: 

 2、边框阴影 box-shadow

box-shadow 用于向方框添加阴影

语法:box-shadow:  X轴偏移量  Y轴偏移量   [阴影模糊半径]    [阴影扩展半径]   [阴影颜色]  [投影方式];

描述
x轴偏移量必需,水平阴影的位置,允许负值。
y轴偏移量必需,垂直阴影的位置,允许负值。
阴影模糊半径可选,模糊距离
阴影扩展半径可选,阴影尺寸
阴影颜色可选,阴影的颜色。省略默认为黑色
投影方式可选,设置inset时为内部阴影方式,省略默认为外阴影方式

举例:

 .box {width: 200px;height: 100px;background-color: #03b3c6;box-shadow: 10px 10px 4px 0px gray;}

效果: 

 

3、自定义字体样式方法

1、定义字体

语法:

@font-face{
   font-family : 字体名称;
   src : url("字体路径")
}

 /* 定义字体 */@font-face {font-family: "毛体";src: url("fonts/maozedong.ttf");}

2、使用字体

语法:

.box{
  font-family : 字体名称;
}

  /* 使用字体 */.box {font-family: "毛体";font-size: 50px;}

举例:

文件层级关系:

 引入与使用方法举例:

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>字体练习</title><style type="text/css">/* 字体存放文件命名应为fonts *//* 引入字体标签 */@font-face {font-family: "mfd";/* 引号内写自己命名的字体名 *//* 接下来引入字体路径 */src: url("fonts/MFDingDing_Noncommercial-Regular.otf");}/* 使用字体 不同字体间用逗号隔开 */.box {font-family: "mfd";}</style></head><body><div class="box"><p>这个世界名为元泱境界,脉(本质为振动)是构成万物的基础。每隔333年,会有一个神秘而强大的异常生物重生,它就是魁拔!魁拔的每一次出现,都会给元泱境界带来巨大的灾难!即便是天界的神族,也在劫难逃。在天地两界各种力量的全力打击下,魁拔一次次被消灭,但又总是按333年的周期重新出现。魁拔纪元1664年,天神经过精确测算后,在魁拔苏醒前一刻对其进行毁灭性打击。但谁都没有想到,由于一个差错导致新一代魁拔成功地逃脱了致命一击。很快,天界魁拔司和地界神圣联盟均探测到了魁拔依然生还的迹象。因此,找到魁拔,彻底消灭魁拔,再一次成了各地热血勇士的终极目标。</p><p>在偏远的兽国窝窝乡,蛮大人和蛮吉每天为取得象征成功和光荣的妖侠纹耀而刻苦修炼,却把他们生活的村庄搅得鸡犬不宁。村民们绞尽脑汁把他们赶走。一天,消灭魁拔的征兵令突然传到窝窝乡,村长趁机怂恿蛮大人和蛮吉从军参战。然而,在这个一切都凭纹耀说话的世界,仅凭蛮大人现有的一块冒牌纹耀,不要说参军,就连住店的资格都没有。受尽歧视的蛮吉和蛮大人决定,混上那艘即将启程去消灭魁拔的巨型战舰,直接挑战魁拔,用热血换取至高的荣誉。</p></div></body>
</html>

效果:

4、(边框)圆角

语法:border-radius

解释
border-radius:值;四个角圆角一样 
border-radius:值1   值2;值1是左上角与右下角
值2是右上角与左下角
border-radius:值1   值2   值3;

值1是左上角

值2是右上角与左下角

值3是右下角

border-radius:值1   值2   值3   值4;

值1是左上角

值2是右上角

值3是右下角

值4是左下角

举例:

.box{width: 200px;height: 200px;background-color: pink;border-radius: 10px; /* 四个角的圆角值是一样的 */border-radius: 10px 30px;      /* 值一左上右下  值二右上左下  对角 */border-radius: 10px 25px 30px;   /* 值一左上 值二右上左下 值三右 下 */border-radius: 10px 25px 30px 50px;   /* 值一左上 值二右上 值三右下 值四左下  顺时针*/border-radius: 50%; /* 椭圆 */  
} 

5、渐变

1、线性渐变

(1)语法:

background-image : linear-gradient(方向 , 颜色1    颜色1位置 , ....)

(2)方向:

  • 渐变角度:单位deg 例如:45deg
  • to  英文单词  to right  从左向右渐变

(3)颜色位置:

  • 可以是数值+单位
  • 可以是 百分比
background-image: linear-gradient(45deg, red,pink);
background: linear-gradient(red 0%,pink 50%); /*image也可以省略不写*/
background-image: linear-gradient(145deg,pink,blue,pink,blue);
background-image: linear-gradient( to right, red 10px,pink 90px); /* 从左到右 */

2、重复线性渐变

background-image : repeating-linear-gradient()

0%到10% 是red到 yellow ; 10%到20% 是yellow到绿; 重复五次; 
background: repeating-linear-gradient(red, yellow 10%, green 20%);

3、径向渐变

语法:background-image : radial-gradient(形状  半径   圆心位置,颜色1    颜色1位置 , ...) 

background: radial-gradient(circle closest-corner at 40px 60px, #f00 0%,#00f 50%);

值:

(1)shap 形状

  • ellipse  默认 椭圆形
  • circle  圆形

(2)半径  size 渐变大小

farthest-corner  默认 指定径向渐变的半径长度是从圆心到离圆心最远的角
farthest-side  指定径向渐变的半径长度是从圆心到最离圆心远的边
closest-corner  指定径向渐变的半径长度是从圆心到离圆心最近的角
closest-side  指定径向渐变的半径长度是从圆心到离圆心最近的边

(3)position 圆心位置

  • at  x位置  y位置
  • x,y取值:数值+单位、百分比、英文单词left right center top bottom

4、重复径向渐变

语法:background-image : repeating-radial-gradient()

background: repeating-radial-gradient(circle closest-corner at top center, #f00 0%,#00f 50%);

6、过渡  transition

注意:为使效果更佳,应将transition属性写在作用对象身(类)上不要写在:horve 内
过渡属性    transition-property:

过渡持续时长    transition-duration:

过渡的速度    transition-timing-function:

1、ease:(逐渐变慢)默认值,ease函数等同于贝塞尔曲线(0.25, 0.1, 0.25, 1.0).
2、linear:(匀速),linear 函数等同于贝塞尔曲线(0.0, 0.0, 1.0, 1.0).
3、ease-in:(加速),ease-in 函数等同于贝塞尔曲线(0.42, 0, 1.0, 1.0).
4、ease-out:(减速),ease-out 函数等同于贝塞尔曲线(0, 0, 0.58, 1.0).
5、ease-in-out:(加速然后减速),ease-in-out 函数等同于贝塞尔曲线(0.42, 0, 0.58, 1.0)
6、cubic-bezier(x1,y1,x2,y2):(该值允许你去自定义一个时间曲线), 特定的cubic-bezier曲线。 (x1, y1, x2, y2)  四个值特定于曲线上点P1和点P2。所有值需在[0, 1]区域内,否则无效。
过渡的延迟    transition-delay:

简写:transition: all 5s ease 0s;(all意思为所有的,所有属性)

简写2(常用)transition: 0.3s;

不使用all也可定义指定属性:transition: background 0.3s;

7、理论知识:理解重绘(/重排)与回流

详细讲解重绘与回流https://blog.csdn.net/a419419/article/details/90402561

   回流:当render tree(渲染树)中的一部分(或全部)因为元素的规模尺寸,布局,隐藏等改变而需要重新构建, 这就称为回流(reflow)。每个页面至少需要一次回流,就是在页面第一次加载的时候。

        重绘:在回流的时候,浏览器会使渲染树中受到影响的部分失效,并重新构造这部分渲染树,完成回流后,浏览器会重新绘制受影响的部分到屏幕中,该过程成为重绘。

回流必将引起重绘,而重绘不一定会引起回流。回流会导致渲染树需要重新计算,开销比重绘大,所以我们要尽量避免回流的产生。

8、渐进增强和优雅降级的区别 


渐进增强:开始就针对低版本浏览器进行构建页面,完成基本的功能,然后再针对高级浏览器进行效果、交互、追加功能以达到更好的体验。

优雅降级:一开始就构建站点的完整功能,然后针对浏览器测试和修复。比如一开始使用 CSS3 的特性构建了一个应用,然后逐步针对各大浏览器进行 hack 使其可以在低版本浏览器上正常浏览。

区别: 

优雅降级认为应该针对那些最高级、最完善的浏览器来设计网站。而将那些有功能缺失的浏览器下的测试工作安排在开发周期的最后阶段,并把测试对象限定为主流浏览器的前一个版本。在这种设计下,旧版的浏览器被认为仅能提供最简单的的浏览体验。(优先关注最高级的,再考虑兼容)

渐进增强认为应关注于内容本身。会优先考虑老版本浏览器的可用性,最后才考虑新版本的可用性,这使得渐进增强成为一种更为合理的设计范例。(先考虑兼容)

低版本用户居多,优先采用渐进增强的开发流程;如果高版本用户居多,为了提高大多数用户的使用体验,优先采用优雅降级的开发流程。不过大多数情况下都是采用渐进增强的方式,因为它更加合理。

这篇关于自定义字体样式引入使用方法、文本阴影、边框阴影、(边框)圆角、渐变、理解重绘与回流、渐进增强和优雅降级的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/898739

相关文章

setsid 命令工作原理和使用案例介绍

《setsid命令工作原理和使用案例介绍》setsid命令在Linux中创建独立会话,使进程脱离终端运行,适用于守护进程和后台任务,通过重定向输出和确保权限,可有效管理长时间运行的进程,本文给大家介... 目录setsid 命令介绍和使用案例基本介绍基本语法主要特点命令参数使用案例1. 在后台运行命令2.

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

使用Python的requests库调用API接口的详细步骤

《使用Python的requests库调用API接口的详细步骤》使用Python的requests库调用API接口是开发中最常用的方式之一,它简化了HTTP请求的处理流程,以下是详细步骤和实战示例,涵... 目录一、准备工作:安装 requests 库二、基本调用流程(以 RESTful API 为例)1.

Python清空Word段落样式的三种方法

《Python清空Word段落样式的三种方法》:本文主要介绍如何用python-docx库清空Word段落样式,提供三种方法:设置为Normal样式、清除直接格式、创建新Normal样式,注意需重... 目录方法一:直接设置段落样式为"Normal"方法二:清除所有直接格式设置方法三:创建新的Normal样

在Linux系统上连接GitHub的方法步骤(适用2025年)

《在Linux系统上连接GitHub的方法步骤(适用2025年)》在2025年,使用Linux系统连接GitHub的推荐方式是通过SSH(SecureShell)协议进行身份验证,这种方式不仅安全,还... 目录步骤一:检查并安装 Git步骤二:生成 SSH 密钥步骤三:将 SSH 公钥添加到 github

把Python列表中的元素移动到开头的三种方法

《把Python列表中的元素移动到开头的三种方法》在Python编程中,我们经常需要对列表(list)进行操作,有时,我们希望将列表中的某个元素移动到最前面,使其成为第一项,本文给大家介绍了把Pyth... 目录一、查找删除插入法1. 找到元素的索引2. 移除元素3. 插入到列表开头二、使用列表切片(Lis

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl