Maison interface Web tutoriel HTML 【01】CSS3 Gradient 分为 linear-gradient(线性渐变)和 radial-gradient(径 向渐变)_html/css_WEB-ITnose

【01】CSS3 Gradient 分为 linear-gradient(线性渐变)和 radial-gradient(径 向渐变)_html/css_WEB-ITnose

Jun 24, 2016 am 11:26 AM

 CSS3 Gradient 分为 linear-gradient(线性渐变)和 radial-gradient(径 向渐变)。而我们今天主要是针对线性渐变来剖析其具体的用法。为了更好的应用 CSS3 Gradient,我们需要先了解一下目前的几种现代浏览器的内核,主要有 Mozilla(Firefox,Flock等)、 WebKit(Safari、Chrome等)、Opera(Opera浏览器)、Trident(讨厌的IE浏览器)。

  本文照常忽略IE不管,我们主要看看在 Mozilla、Webkit、Opera 下的应用,当然在 IE 下也可以实现,他需要通过 IE 特有的滤镜来实现,在后面会列出滤镜的使用语法,但不会具体介绍如何实用,感兴趣的可以搜索相关技术文档。

一、线性渐变在 Mozilla 下的应用

  语法:


  1. -moz-linear-gradient([||,]?,[,]*)

 

  参数:其共有三个参数,第一个参数表示线性渐变的方向,top 是从上到下、left 是从左到右,如果定义成 left top,那就是从左上角到右下角。

第二个和第三个参数分别是起点颜色和终点颜色。你还可以在它们之间插入更多的参数,表示多种颜色的渐变。如图所示:

  

  根据上面的介绍,我们先来看一个简单的例子:

  HTML:

 

 

  CSS:

  1. .example {
  2. width:150px;
  3. height:80px;
  4. }

 

 

  如无特殊说明,我们后面的示例都是应用这一段 html 和 css 的基本代码。

  现在我们给这个div应用一个简单的渐变样式:

  1. .example1 {
  2. background:-moz-linear-gradient( top,#ccc,#000);
  3. }

 

 

  效果如下:

  

二、线性渐变在 Webkit 下的应用

  语法:

  1. -webkit-linear-gradient([||,]?,[,]*)//最新发布书写语法
  2. -webkit-gradient(,[,]?,[,]?[,]*)//老式语法书写规则

  参数:-webkit-gradient 是 webkit 引擎对渐变的实现参数,一共有五个。第一个参数表示渐变类型(type),可以是linear(线性渐变)或者radial(径向渐变)。第二个参数和第 三个参数,都是一对值,分别表示渐变起点和终点。这对值可以用坐标形式表示,也可以用关键值表示,比如 left top(左上角)和left bottom(左下角)。第四个和第五个参数,分别是两个color-stop函数。color-stop 函数接受两个参数,第一个表示渐变的位置,0为起点,0.5为中点,1为结束点;第二个表示该点的颜色。如图所示:

  

  

  我们先来看一个老式的写法示例:

  1. background:-webkit-gradient(linear,center top,center bottom,from(#ccc), to(#000));

 

 

  效果如下所示:

  

  接着我们在来看一下新式的写法:

  1. -webkit-linear-gradient(top,#ccc,#000);

 

  这个效果我就不在贴出来了,大家在浏览器中一看就明白了,他们是否一致的效果。仔细对比,在 Mozilla 和 Webkit下两者的写法都基本上一致了,只是其前缀的区别,当然哪一天他们能统一成一样,对我们来说当然是更好了,那就不用去处理了。将大大节省我们的开发时间哟。

三、线性渐变在 Opera 下的应用

  语法:

  1. -o-linear-gradient([||,]?,[,]);/* Opera 11.10+ */

 

  参数:-o-linear-gradient 有三个参数。第一个参数表示线性渐变的方向,top是从上到下、left 是从左到右,如果定义成 lefttop,那就是从左上角到右下角。第二个和第三个参数分别是起点颜色和终点颜色。你还可以在它们之间插入更多的参数,表示多种颜色的渐变。(注:Opera 支持的版本有限,本例测试都是在 Opera11.1 版本下,后面不在提示),如图所示:

  

  示例代码:

  1. background:-o-linear-gradient(top,#ccc,#000);

 

 

  效果如图所示:

  

四、线性渐变在 Trident (IE) 下的应用

  语法:

  1. filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr=#1471da, endColorstr=#1C85FB);/*IE*/
  2. -ms-filter:"progid:DXImageTransform.Microsoft.gradient (GradientType=0, startColorstr=#1471da, endColorstr=#1C85FB)";/*IE8+*/

 

 

  IE依靠滤镜实现渐变。startColorstr表示起点的颜色,endColorstr 表示终点颜色。GradientType 表示渐变类型,0 为缺省值,表示垂直渐变,1 表示水平渐变。如图所示:

  

  上面我们主要介绍了线性渐变在上述四大核心模块下的实现方法,接着我们主要针对线性渐变在 Mozilla、Webkit、Opera 三大模块下实现各种不同线性渐变实例:

  从上面的语法中我们可以很清楚的知道,要创建一个线性渐变,我们需要创建一个起点和一个渐变方向(或角度),定义一个起始色:

  1. -moz-linear-gradient([||,]?,[,]*)
  2. -webkit-linear-gradient([||,]?,[,]*)
  3. -o-linear-gradient([||,]?,[,]*)

 

  具体应用如下:

  1. background:-moz-linear-gradient(left,#ace,#f96);/*Mozilla*/
  2. background:-webkit-gradient(linear,050%,100%50%,from(#ace),to(#f96));/*Old gradient for webkit*/
  3. background:-webkit-linear-gradient(left,#ace,#f96);/*new gradient for Webkit*/
  4. background:-o-linear-gradient(left,#ace,#f96);/*Opera11*/

 

  效果如下:

  

  起始点(Starting Point)的工作方式类似于 backgroundposition。您可以设置水平和垂直位置为百分比,或以像素为单位,或在水平方向上可以使用left/center/right,在垂直方向上可以使用top/center/bottom。位置起始于左上角。如果你不指定水平或垂直位置,它将默认为center。其工作方式主要包含:Top →Bottom、Left → Right、bottom → top、right → left等,接着我们主要一种一种来看其实现的效果:

  1、开始于center(水平方向)和top(垂直方向)也就是Top → Bottom:

  1. /* Firefox 3.6+ */
  2. background:-moz-linear-gradient(top,#ace,#f96);
  3. /* Safari 4-5, Chrome 1-9 */
  4. /* -webkit-gradient(, [, ]?, [, ]? [, ]*) */
  5. background:-webkit-gradient(linear,top,from(#ace),to(#f96));
  6. /* Safari 5.1+, Chrome 10+ */
  7. background:-webkit-linear-gradient(top,#ace,#f96);
  8. /* Opera 11.10+ */
  9. background:-o-linear-gradient(top,#ace,#f96);

 

  效果:

  

  2、始于left(水平方向)和center(垂直方向)也是就Left → Right:

  1. /* Firefox 3.6+ */
  2. background:-moz-linear-gradient(left,#ace,#f96);
  3. /* Safari 5.1+, Chrome 10+ */
  4. background:-webkit-linear-gradient(left,#ace,#f96);
  5. /* Opera 11.10+ */
  6. background:-o-linear-gradient(left,#ace,#f96);

 

  效果如下:

  

  3、起始于left(水平方向)和top(垂直方向):

  1. background:-moz-linear-gradient(left top,#ace,#f96);
  2. background:-webkit-linear-gradient(left top,#ace,#f96);
  3. background:-o-linear-gradient(left top,#ace,#f96);

 

  效果如下:

  

  4、Linear Gradient (with Even Stops):

  1. /* Firefox 3.6+ */
  2. background:-moz-linear-gradient(left,#ace,#f96,#ace,#f96,#ace);
  3. /* Safari 4-5, Chrome 1-9 */
  4. background:-webkit-gradient(linear, left top, right top, from(#ace), color-stop(0.25,#f96), color-stop(0.5,#ace), color-stop(0.75,#f96), to(#ace));
  5. /* Safari 5.1+, Chrome 10+ */
  6. background:-webkit-linear-gradient(left,#ace,#f96,#ace,#f96,#ace);
  7. /* Opera 11.10+ */
  8. background:-o-linear-gradient(left,#ace,#f96,#ace,#f96,#ace);

 

  效果如下:

  

  5、with Specified Arbitrary Stops:

  1. /* Firefox 3.6+ */
  2. background:-moz-linear-gradient(left,#ace,#f96 5%,#ace,#f96 95%,#ace);
  3. /* Safari 4-5, Chrome 1-9 */
  4. background:-webkit-gradient(linear, left top, right top, from(#ace), color-stop(0.05,#f96), color-stop(0.5,#ace), color-stop(0.95,#f96), to(#ace));
  5. /* Safari 5.1+, Chrome 10+ */
  6. background:-webkit-linear-gradient(left,#ace,#f96 5%,#ace,#f96 95%,#ace);
  7. /* Opera 11.10+ */
  8. background:-o-linear-gradient(left,#ace,#f96 5%,#ace,#f96 95%,#ace);

 

  效果如下:

  

  6、角度(Angle):

  正如上面看到的示例,如果您不指定一个角度,它会根据起始位置自动定义。如果你想更多的控制渐变的方向,您不妨设置角度试试。例如,下面的两个渐变具有相同的起点left center,但是加上一个30度的角度。

  没有角度的示例代码:

  1. background:-moz-linear-gradient(left,#ace,#f96);
  2. background:-webkit-linear-gradient(left,#ace,#f96);
  3. background:-o-linear-gradient(left,#ace,#f96);

 

  加上30度的角度代码:

  1. background:-moz-linear-gradient(left 30deg,#ace,#f96);
  2. background:-webkit-gradient(linear,00,100%100%, from(#ace),to(#f96));
  3. background:-o-linear-gradient(30deg,#ace,#f96);

 

  效果图如下:

 

      

  当指定的角度,请记住,它是一个由水平线与渐变线产生的的角度,逆时针方向。因此,使用0deg将产生一个左到右横向梯度,而90度将创建一个从底部到顶部的垂直渐变。我来看看你核心代码:

  1. background:-moz-linear-gradient(,#ace,#f96);
  2. background:-webkit-gradient(,, from(#ace), to(#f96));
  3. background:-webkit-linear-gradient(,#ace,#f96);
  4. background:-o-linear-gradient(,#ace,#f96);

 

  我们来看看各角度的区别:

  1. .deg0 {
  2. background:-moz-linear-gradient(0deg,#ace,#f96);
  3. background:-webkit-gradient(linear,050%,100%50%,from(#ace),to(#f96));
  4. background:-webkit-linear-gradient(0deg,#ace,#f96);
  5. background:-o-linear-gradient(0deg,#ace,#f96);
  6. }
  7. .deg45 {
  8. background:-moz-linear-gradient(45deg,#ace,#f96);
  9. background:-webkit-gradient(linear,0100%,100%0%,from(#ace),to(#f96));
  10. background:-webkit-linear-gradient(45deg,#ace,#f96);
  11. background:-o-linear-gradient(45deg,#ace,#f96);
  12. }
  13. .deg90 {
  14. background:-moz-linear-gradient(90deg,#ace,#f96);
  15. background:-webkit-gradient(linear,50%100%,50%0%,from(#ace),to(#f96));
  16. background:-webkit-linear-gradient(90deg,#ace,#f96);
  17. background:-o-linear-gradient(90deg,#ace,#f96);
  18. }
  19. .deg135 {
  20. background:-moz-linear-gradient(135deg,#ace,#f96);
  21. background:-webkit-gradient(linear,100%100%,00,from(#ace),to(#f96));
  22. background:-webkit-linear-gradient(135deg,#ace,#f96);
  23. background:-o-linear-gradient(135deg,#ace,#f96);
  24. }
  25. .deg180 {
  26. background:-moz-linear-gradient(180deg,#ace,#f96);
  27. background:-webkit-gradient(linear,100%50%,050%,from(#ace),to(#f96));
  28. background:-webkit-linear-gradient(180deg,#ace,#f96);
  29. background:-o-linear-gradient(180deg,#ace,#f96);
  30. }
  31. .deg225 {
  32. background:-moz-linear-gradient(225deg,#ace,#f96);
  33. background:-webkit-gradient(linear,100%0%,0100%,from(#ace),to(#f96));
  34. background:-webkit-linear-gradient(225deg,#ace,#f96);
  35. background:-o-linear-gradient(225deg,#ace,#f96);
  36. }
  37. .deg270 {
  38. background:-moz-linear-gradient(270deg,#ace,#f96);
  39. background:-webkit-gradient(linear,50%0%,50%100%,from(#ace),to(#f96));
  40. background:-webkit-linear-gradient(270deg,#ace,#f96);
  41. background:-o-linear-gradient(270deg,#ace,#f96);
  42. }
  43. .deg315 {
  44. background:-moz-linear-gradient(315deg,#ace,#f96);
  45. background:-webkit-gradient(linear,0%0%,100%100%,from(#ace),to(#f96));
  46. background:-webkit-linear-gradient(315deg,#ace,#f96);
  47. background:-o-linear-gradient(315deg,#ace,#f96);
  48. }
  49. .deg360 {
  50. background:-moz-linear-gradient(360deg,#ace,#f96);
  51. background:-webkit-gradient(linear,050%,100%50%,from(#ace),to(#f96));
  52. background:-webkit-linear-gradient(360deg,#ace,#f96);
  53. background:-o-linear-gradient(360deg,#ace,#f96);
  54. }

 

  效果如下:

 

  

  除了起始位置和角度,你应该指定起止颜色。起止颜色是沿着渐变线,将会在指定位置(以百分比或长度设定)含有指定颜色的点。色彩的起止数是无限的。如果您使用一个百分比位置,0%代表起点和100%是终点,但区域外的值可以被用来达到预期的效果。 这也是通过CSS3Gradient制作渐变的一个关键所在,其直接影响了你的设计效果,像我们这里的示例都不是完美的效果,只是为了能给大家展示一个渐变的效果,大家就这样先用着吧。我们接着看一下不同的起址色的示例:

  1. background:-moz-linear-gradient(top,#ace,#f96 80%,#f96);
  2. background:-webkit-linear-gradient(top,#ace,#f96 80%,#f96);
  3. background:-o-linear-gradient(top,#ace,#f96 80%,#f96);

 

  效果如下:

 

  

  如果没有指定位置,颜色会均匀分布。如下面的示例:

  1. background:-moz-linear-gradient(left, red,#f96, yellow, green,#ace);
  2. background:-webkit-linear-gradient(left,red,#f96,yellow,green,#ace);
  3. background:-o-linear-gradient(left, red,#f96, yellow, green,#ace);

 

  效果如下

 

 

  7、渐变上应用透明度(Transparency):

  透明渐变对于制作一些特殊的效果是相当有用的,例如,当堆叠多个背景时。这里是两个背景的结合:一张图片,一个白色到透明的线性渐变。我们来看一个官网的示例吧:

  1. background:-moz-linear-gradient(right, rgba(255,255,255,0), rgba(255,255,255,1)),url(http://demos.hacks.mozilla.org/openweb/resources/images/patterns/flowers-pattern.jpg);
  2. background:-webkit-linear-gradient(right, rgba(255,255,255,0), rgba(255,255,255,1)),url(http://demos.hacks.mozilla.org/openweb/resources/images/patterns/flowers-pattern.jpg);
  3. background:-o-linear-gradient(right, rgba(255,255,255,0), rgba(255,255,255,1)),url(http://demos.hacks.mozilla.org/openweb/resources/images/patterns/flowers-pattern.jpg);

 

  接着看看效果吧

  

 



 



Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quel est le but du & lt; Progress & gt; élément? Quel est le but du & lt; Progress & gt; élément? Mar 21, 2025 pm 12:34 PM

L'article traite du HTML & lt; Progress & GT; élément, son but, son style et ses différences par rapport au & lt; mètre & gt; élément. L'objectif principal est de l'utiliser & lt; Progress & gt; pour l'achèvement des tâches et & lt; mètre & gt; pour stati

Quel est le but du & lt; datalist & gt; élément? Quel est le but du & lt; datalist & gt; élément? Mar 21, 2025 pm 12:33 PM

L'article traite du HTML & lt; Datalist & GT; élément, qui améliore les formulaires en fournissant des suggestions de saisie semi-automatique, en améliorant l'expérience utilisateur et en réduisant les erreurs. COMMANDE COMPRES: 159

Quelles sont les meilleures pratiques pour la compatibilité entre les navigateurs dans HTML5? Quelles sont les meilleures pratiques pour la compatibilité entre les navigateurs dans HTML5? Mar 17, 2025 pm 12:20 PM

L'article examine les meilleures pratiques pour assurer la compatibilité des navigateurs de HTML5, en se concentrant sur la détection des fonctionnalités, l'amélioration progressive et les méthodes de test.

Quel est le but du & lt; mètre & gt; élément? Quel est le but du & lt; mètre & gt; élément? Mar 21, 2025 pm 12:35 PM

L'article traite du HTML & lt; mètre & gt; élément, utilisé pour afficher des valeurs scalaires ou fractionnaires dans une plage, et ses applications courantes dans le développement Web. Il différencie & lt; mètre & gt; De & lt; Progress & gt; et ex

Comment utiliser le html5 & lt; time & gt; élément pour représenter les dates et les temps sémantiquement? Comment utiliser le html5 & lt; time & gt; élément pour représenter les dates et les temps sémantiquement? Mar 12, 2025 pm 04:05 PM

Cet article explique le html5 & lt; time & gt; élément de représentation sémantique de date / heure. Il souligne l'importance de l'attribut DateTime pour la lisibilité à la machine (format ISO 8601) à côté du texte lisible par l'homme, stimulant AccessIbilit

Comment utiliser les attributs de validation du formulaire HTML5 pour valider l'entrée utilisateur? Comment utiliser les attributs de validation du formulaire HTML5 pour valider l'entrée utilisateur? Mar 17, 2025 pm 12:27 PM

L'article discute de l'utilisation des attributs de validation de formulaire HTML5 comme les limites requises, motifs, min, max et longueurs pour valider la saisie de l'utilisateur directement dans le navigateur.

Quelle est la balise Meta de la fenêtre? Pourquoi est-ce important pour une conception réactive? Quelle est la balise Meta de la fenêtre? Pourquoi est-ce important pour une conception réactive? Mar 20, 2025 pm 05:56 PM

L'article traite de la balise Meta de la fenêtre, essentielle pour la conception Web réactive sur les appareils mobiles. Il explique comment une utilisation appropriée garantit une mise à l'échelle optimale du contenu et une interaction utilisateur, tandis que la mauvaise utilisation peut entraîner des problèmes de conception et d'accessibilité.

Quel est le but du & lt; iframe & gt; étiqueter? Quelles sont les considérations de sécurité lorsque vous l'utilisez? Quel est le but du & lt; iframe & gt; étiqueter? Quelles sont les considérations de sécurité lorsque vous l'utilisez? Mar 20, 2025 pm 06:05 PM

L'article traite du & lt; iframe & gt; L'objectif de Tag dans l'intégration du contenu externe dans les pages Web, ses utilisations courantes, ses risques de sécurité et ses alternatives telles que les balises d'objet et les API.

See all articles