CSS3, 선형 그래디언트 사용 요약(linear-gradient)

高洛峰
풀어 주다: 2017-02-11 14:02:49
원래의
1890명이 탐색했습니다.

오늘 글에서는 그라데이션 효과를 얻기 위해 CSS3에서 Gradient 속성을 구체적으로 사용하는 방법을 살펴보겠습니다. 예전에는 그림자 효과나 둥근 모서리 효과 같은 그라데이션 효과를 모두 그림으로 만들었고, CSS 코드를 직접 작성하면 가능했습니다.

이전 기사에서는 "CSS3 클래식 튜토리얼 시리즈"에서 텍스트-그림자 텍스트 그림자 기능의 사용법을 자세히 소개했습니다. 오늘 기사에서는 그라데이션 효과를 구현하는 Gradient 속성에 대해 살펴보겠습니다. CSS3.특정 사용법. 예전에는 그림자 효과나 둥근 모서리 효과 같은 그라데이션 효과를 모두 그림으로 만들었고, CSS 코드를 직접 작성하면 가능했습니다.

CSS3 그래디언트는 선형 그래디언트(선형 그래디언트)와 방사형 그래디언트(방사형 그래디언트)로 구분됩니다. 오늘 우리는 주로 선형 그래디언트의 구체적인 사용법을 분석하고 있습니다. CSS3 Gradient를 더 잘 적용하려면 먼저 Mozilla(Firefox, Flock 등), WebKit(Safari, Chrome 등), Opera(Opera 브라우저), Trident(Annoying) 등 여러 최신 브라우저의 핵심을 이해해야 합니다. IE 브라우저).

이 기사에서는 평소처럼 IE를 무시합니다. Mozilla, Webkit, Opera에서의 애플리케이션을 주로 살펴봅니다. 물론 IE 전용 필터를 통해 구현해야 합니다. 필터 사용 구문에 대해서는 자세히 소개하지 않습니다. 관심 있는 경우 관련 기술 문서를 검색해 보세요.

1. Mozilla에서 선형 그래디언트 적용

구문:


-moz-linear-gradient( [<point> || <angle>,]? <stop>, <stop> [, <stop>]* )</stop></stop></stop></angle></point>
로그인 후 복사


매개변수: It 첫 번째 매개변수는 선형 그래디언트의 방향을 나타내며 위쪽은 위에서 아래로, 왼쪽은 왼쪽에서 오른쪽으로 정의됩니다. 두 번째와 세 번째 매개변수는 각각 시작 색상과 끝 색상입니다. 여러 색상의 그라데이션을 나타내기 위해 그 사이에 더 많은 매개변수를 삽입할 수도 있습니다. 그림과 같이:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

위의 소개에 따라 먼저 간단한 예를 살펴보겠습니다.

HTML:


<p></p>
로그인 후 복사


CSS:


.example {

   width: 150px;

   height: 80px;

 }
로그인 후 복사


특별한 사항이 없으면 다음 예제에서는 모두 HTML과 CSS의 기본 코드를 사용합니다.

이제 이 p에 간단한 그라데이션 스타일을 적용합니다.


.example1 {

   background: -moz-linear-gradient( top,#ccc,#000);

}
로그인 후 복사


효과는 다음과 같습니다.

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

2. Webkit에서 선형 그래디언트 적용

구문:


-webkit-linear-gradient( [<point> || <angle>,]? <stop>, <stop> [, <stop>]* )//最新发布书写语法

-webkit-gradient(<type>, <point> [, <radius>]?, <point> [, <radius>]? [, <stop>]*) //老式语法书写规则</stop></radius></point></radius></point></type></stop></stop></stop></angle></point>
로그인 후 복사


매개변수: -webkit-gradient는 웹킷 엔진의 그래디언트 구현 매개변수로 총 5개가 있습니다. 첫 번째 매개변수는 선형(선형 그라데이션) 또는 방사형(방사형 그라데이션)일 수 있는 그라데이션 유형(유형)을 나타냅니다. 두 번째 매개변수와 세 번째 매개변수는 모두 한 쌍의 값으로, 각각 그래디언트의 시작점과 끝점을 나타냅니다. 이 값 쌍은 왼쪽 위(왼쪽 위 모서리), 왼쪽 아래(왼쪽 아래 모서리) 등 좌표나 키 값의 형태로 표현될 수 있습니다. 네 번째와 다섯 번째 매개변수는 각각 두 가지 색상 정지 기능입니다. 색상 정지 기능은 두 개의 매개변수를 받습니다. 첫 번째 매개변수는 그라디언트의 위치를 ​​나타내고, 0은 시작점, 0.5는 중간점, 1은 끝점의 색상을 나타냅니다. 그림과 같이:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

 CSS3, 선형 그래디언트 사용 요약(linear-gradient)

먼저 옛날 방식의 쓰기 예를 살펴보겠습니다.

코드 복사

코드는 다음과 같습니다:

배경: -webkit-gradient(linear,center top,center Bottom,from(#ccc), to(#000));

효과는 다음과 같습니다.

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

그럼 새로운 글쓰기 방식을 살펴보겠습니다.


-webkit-linear-gradient(top,#ccc,#000);
로그인 후 복사


이 효과는 더 이상 게시하지 않겠습니다. 브라우저에서 보면 동일한 효과가 있는지 확인할 수 있습니다. 잘 비교해 보면 Mozilla와 Webkit의 학습 방법은 접두어의 차이를 제외하면 기본적으로 동일합니다. 물론 언젠가 통합될 수 있다면 더 나을 것이므로 다루지 않아도 됩니다. . 이는 우리의 개발 시간을 크게 절약해 줄 것입니다.

3. Opera에서 선형 그래디언트 적용

구문:

코드 복사

코드는 다음과 같습니다.

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

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

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

示例代码:


background: -o-linear-gradient(top,#ccc, #000);
로그인 후 복사


效果如图所示:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

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

语法:


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

-ms-filter: "progid:DXImageTransform.Microsoft.gradient (GradientType=0, startColorstr=#1471da, endColorstr=#1C85FB)";/*IE8+*/
로그인 후 복사


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

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

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

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


-moz-linear-gradient( [<point> || <angle>,]? <stop>, <stop> [, <stop>]* )

-webkit-linear-gradient( [<point> || <angle>,]? <stop>, <stop> [, <stop>]* )

-o-linear-gradient( [<point> || <angle>,]? <stop>, <stop> [, <stop>]* )</stop></stop></stop></angle></point></stop></stop></stop></angle></point></stop></stop></stop></angle></point>
로그인 후 복사


具体应用如下:


background:-moz-linear-gradient(left,#ace,#f96);/*Mozilla*/

background:-webkit-gradient(linear,0 50%,100% 50%,from(#ace),to(#f96));/*Old gradient for webkit*/

background:-webkit-linear-gradient(left,#ace,#f96);/*new gradient for Webkit*/

background:-o-linear-gradient(left,#ace,#f96); /*Opera11*/
로그인 후 복사


效果如下:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

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

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


/* Firefox 3.6+ */

background: -moz-linear-gradient(top, #ace, #f96); 

/* Safari 4-5, Chrome 1-9 */

/* -webkit-gradient(,  [, ]?,  [, ]? [, ]*) */

background: -webkit-gradient(linear,top,from(#ace),to(#f96));

/* Safari 5.1+, Chrome 10+ */

background: -webkit-linear-gradient(top, #ace, #f96);

/* Opera 11.10+ */

background: -o-linear-gradient(top, #ace, #f96);
로그인 후 복사


效果:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

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


/* Firefox 3.6+ */

background: -moz-linear-gradient(left, #ace, #f96);

/* Safari 5.1+, Chrome 10+ */

background: -webkit-linear-gradient(left, #ace, #f96);

/* Opera 11.10+ */

background: -o-linear-gradient(left, #ace, #f96);
로그인 후 복사


效果如下:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

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


background: -moz-linear-gradient(left top, #ace, #f96);

background: -webkit-linear-gradient(left top, #ace, #f96);

background: -o-linear-gradient(left top, #ace, #f96);
로그인 후 복사


效果如下:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

4、Linear Gradient (with Even Stops):


/* Firefox 3.6+ */

background: -moz-linear-gradient(left, #ace, #f96, #ace, #f96, #ace); 

/* Safari 4-5, Chrome 1-9 */

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)); 

/* Safari 5.1+, Chrome 10+ */

background: -webkit-linear-gradient(left, #ace, #f96, #ace, #f96, #ace); 

/* Opera 11.10+ */

background: -o-linear-gradient(left, #ace, #f96, #ace, #f96, #ace);
로그인 후 복사


效果如下:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

5、with Specified Arbitrary Stops:


/* Firefox 3.6+ */

 background: -moz-linear-gradient(left, #ace, #f96 5%, #ace, #f96 95%, #ace); 

 /* Safari 4-5, Chrome 1-9 */

 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)); 

 /* Safari 5.1+, Chrome 10+ */

 background: -webkit-linear-gradient(left, #ace, #f96 5%, #ace, #f96 95%, #ace); 

 /* Opera 11.10+ */

 background: -o-linear-gradient(left, #ace, #f96 5%, #ace, #f96 95%, #ace);
로그인 후 복사


效果如下:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

6、角度(Angle):

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

没有角度的示例代码:


background: -moz-linear-gradient(left, #ace, #f96);

background: -webkit-linear-gradient(left,#ace,#f96);

background: -o-linear-gradient(left, #ace, #f96);
로그인 후 복사


加上30度的角度代码:


background: -moz-linear-gradient(left 30deg, #ace, #f96);

background: -webkit-gradient(linear, 0 0, 100% 100%, from(#ace),to(#f96));

background: -o-linear-gradient(30deg, #ace, #f96);
로그인 후 복사


效果图如下:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)CSS3, 선형 그래디언트 사용 요약(linear-gradient)

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


background: -moz-linear-gradient(<angle>, #ace, #f96);

background: -webkit-gradient(<type>,<angle>, from(#ace), to(#f96));

background: -webkit-linear-gradient(<angle>, #ace, #f96);

background: -o-linear-gradient(<angle>, #ace, #f96);</angle></angle></angle></type></angle>
로그인 후 복사


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


.deg0 {

  background: -moz-linear-gradient(0deg, #ace, #f96);

  background: -webkit-gradient(linear,0 50%,100% 50%,from(#ace),to(#f96));

  background: -webkit-linear-gradient(0deg, #ace, #f96);

  background: -o-linear-gradient(0deg, #ace, #f96);

}

     

.deg45 {

  background: -moz-linear-gradient(45deg, #ace, #f96);

  background: -webkit-gradient(linear,0 100%,100% 0%,from(#ace),to(#f96));

  background: -webkit-linear-gradient(45deg, #ace, #f96);

  background: -o-linear-gradient(45deg, #ace, #f96);

}

.deg90 {

  background: -moz-linear-gradient(90deg, #ace, #f96);

  background: -webkit-gradient(linear,50% 100%,50% 0%,from(#ace),to(#f96));

  background: -webkit-linear-gradient(90deg, #ace, #f96);

  background: -o-linear-gradient(90deg, #ace, #f96);

}

.deg135 {

  background: -moz-linear-gradient(135deg, #ace, #f96);

  background: -webkit-gradient(linear,100% 100%,0 0,from(#ace),to(#f96));

  background: -webkit-linear-gradient(135deg, #ace, #f96);

  background: -o-linear-gradient(135deg, #ace, #f96);

}

.deg180 {

  background: -moz-linear-gradient(180deg, #ace, #f96);

  background: -webkit-gradient(linear,100% 50%,0 50%,from(#ace),to(#f96));

  background: -webkit-linear-gradient(180deg, #ace, #f96);

  background: -o-linear-gradient(180deg, #ace, #f96);

}

.deg225 {

  background: -moz-linear-gradient(225deg, #ace, #f96);

  background: -webkit-gradient(linear,100% 0%,0 100%,from(#ace),to(#f96));

  background: -webkit-linear-gradient(225deg, #ace, #f96);

  background: -o-linear-gradient(225deg, #ace, #f96);

}

.deg270 {

  background: -moz-linear-gradient(270deg, #ace, #f96);

  background: -webkit-gradient(linear,50% 0%,50% 100%,from(#ace),to(#f96));

  background: -webkit-linear-gradient(270deg, #ace, #f96);

  background: -o-linear-gradient(270deg, #ace, #f96);

}

.deg315 {

  background: -moz-linear-gradient(315deg, #ace, #f96);

  background: -webkit-gradient(linear,0% 0%,100% 100%,from(#ace),to(#f96));

  background: -webkit-linear-gradient(315deg, #ace, #f96);

  background: -o-linear-gradient(315deg, #ace, #f96);

}

.deg360 {

  background: -moz-linear-gradient(360deg, #ace, #f96);

  background: -webkit-gradient(linear,0 50%,100% 50%,from(#ace),to(#f96));

  background: -webkit-linear-gradient(360deg, #ace, #f96);

  background: -o-linear-gradient(360deg, #ace, #f96);

}
로그인 후 복사


效果如下:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

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


background: -moz-linear-gradient(top, #ace, #f96 80%, #f96);

background: -webkit-linear-gradient(top,#ace,#f96 80%,#f96);

background: -o-linear-gradient(top, #ace, #f96 80%, #f96);
로그인 후 복사


效果如下:

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

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


background: -moz-linear-gradient(left, red, #f96, yellow, green, #ace);

background: -webkit-linear-gradient(left,red,#f96,yellow,green,#ace);

background: -o-linear-gradient(left, red, #f96, yellow, green, #ace);
로그인 후 복사


效果如下

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

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

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


background: -moz-linear-gradient(right, rgba(255,255,255,0), rgba(255,255,255,1)),url(http://www.php.cn/);

background: -webkit-linear-gradient(right, rgba(255,255,255,0), rgba(255,255,255,1)),url(http://www.php.cn/);

background: -o-linear-gradient(right, rgba(255,255,255,0), rgba(255,255,255,1)),url(http://www.php.cn/);
로그인 후 복사


接着看看效果吧

CSS3, 선형 그래디언트 사용 요약(linear-gradient)

是不是很神奇呀。如果想体会的话,快点动手跟我一起做吧。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持PHP中文网。

更多CSS3, 선형 그래디언트 사용 요약(linear-gradient)相关文章请关注PHP中文网!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿