Maison  >  Article  >  interface Web  >  Compréhension approfondie des compétences d'utilisation de la propriété CSS *-gradient

Compréhension approfondie des compétences d'utilisation de la propriété CSS *-gradient

青灯夜游
青灯夜游avant
2021-02-24 09:43:312239parcourir

Cet article vous apprendra comment utiliser les attributs CSS *-gradient. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il sera utile à tout le monde.

Compréhension approfondie des compétences d'utilisation de la propriété CSS *-gradient

[Tutoriel recommandé : Tutoriel vidéo CSS ]

Permettez-moi d'abord de vous présenter un attribut intéressant—— conic-gradient

Dégradé de cône !

Je m'y intéresse car j'ai trouvé qu'on pouvait l'utiliser pour faire des camemberts !
Par exemple :
Compréhension approfondie des compétences dutilisation de la propriété CSS *-gradient
Comme ceci :
Compréhension approfondie des compétences dutilisation de la propriété CSS *-gradient
Le principe est aussi très simple : prendre le point de départ comme centre, puis réaliser le dégradé autour du centre dans le sens des aiguilles d'une montre. Effet. Il doit recevoir plusieurs paramètres de valeur de couleur. Chaque valeur de couleur peut être suivie de deux pourcentages, qui sont le point de départ et le point d'arrivée de la valeur de couleur actuelle (séparés par des espaces) :

Compréhension approfondie des compétences dutilisation de la propriété CSS *-gradient

background: conic-gradient(pink 0 30%, yellow 0 70%, lime 0 100%);

peut aussi s'écrire séparément :

background: conic-gradient(pink 0, pink 30%, yellow 30%, yellow 70%, lime 70%, lime 100%);

(La deuxième façon est plus compatible que la première)

Attendez ! La deuxième image ci-dessus n’est-elle pas exactement ce que nous souhaitons ?
D'après l'image, il ne nous est pas difficile d'arriver au code suivant :

{
    width: 200px;
    height: 200px;
    background: conic-gradient(deeppink 0, deeppink 30%, yellowgreen 30%, yellowgreen 70%, teal 70%, teal 100%);
    border-radius: 50%;
}

Mais, il est ici complètement "statique".

La plupart d'entre nous ont probablement utilisé des echarts pour dessiner des graphiques : en fonction des données du backend, restituez-les dans les paramètres spécifiés (tableau) de l'objet Map des echarts pour obtenir un cercle affiché dans différentes couleurs qui correspondent les exigences. Comment faire cela en utilisant CSS ?

Bien sûr, nous avons besoin de l'aide de JS - car CSS3 a lancé des variables personnalisées, qui peuvent combiner des attributs CSS avec des variables JavaScript :
Après exploration, Actuellement une meilleure pratique devrait être de définir les positions de début et de fin de la couleur du dégradé en tant que variables personnalisées, puis lorsque JavaScript obtient les données, modifiez sa valeur pour modifier la distribution des couleurs dans le diagramme circulaire !

Mettez une démo que j'ai écrite auparavant :

:root{
	--zero:0;
	--one:50%;
}
.circle{
	width: 300px;
	height: 300px;
	border-radius: 50%;
	/* background: conic-gradient(red, yellow, lime, aqua, blue, fuchsia, red); */
	background: conic-gradient(red var(--zero) var(--one),yellow var(--one) 100%);
}
<div class="circle"></div>
<button id="but">点我改变圆饼图分布</button>
<script>
	but.onclick=function(){
		document.documentElement.style.setProperty(&#39;--zero&#39;, &#39;10%&#39;);
		document.documentElement.style.setProperty(&#39;--one&#39;, &#39;70%&#39;);
	}
</script>

Si vous souhaitez augmenter dynamiquement la valeur de la couleur (comme l'ajout de nouveaux objets d'enquête), vous pouvez modifier dynamiquement les attributs avec style :

xxx.style.xxx="xxx";   //改变

C'est bien plus pratique que d'utiliser "::after pseudo-élément" !

De nombreuses personnes ont peut-être joué avec la méthode des pseudo-éléments : utiliser l'attribut rotate de transform pour faire pivoter une zone de contenu et en afficher une partie pour atteindre l'objectif.

Il existe de nombreuses "opérations sexy" qui devraient être recherchées en ligne, je n'entrerai donc pas dans les détails ici (: par rapport à "l'indifférence" du navigateur à cet attribut au cours des deux dernières années partie actuelle Le support est également une grande amélioration, continuons à l'attendre avec impatience)


À propos de gradient linéaire

Cet attribut est utilisé en plus de utilisé sur certains sites Web. Il semble qu'il n'y ait rien qui mérite d'être pris en compte à l'exception de l'arrière-plan de l'élément :
Par exemple, Fond rayé
« Si plusieurs arrêts de couleur ont la même position, ils créera une zone de transition infinitésimale,
Les couleurs de début et de fin de la transition sont les première et dernière valeurs spécifiées. À partir de l'effet, la couleur changera soudainement à cette
position, plutôt qu'un processus de dégradé fluide.
Parce que le dégradé est une image générée par le code qui peut être traitée comme n'importe quelle autre image d'arrière-plan et peut être redimensionnée via background-size et comme l'arrière-plan est carrelé à plusieurs reprises par défaut, le conteneur entier a en fait été rempli d'horizontale ; rayures :

background: linear-gradient(#fb3 50%, #58a 50%);
background-size: 100% 30px;

Compréhension approfondie des compétences dutilisation de la propriété CSS *-gradient
Rayures verticales
Le code des rayures verticales est presque le même que celui des rayures horizontales. La principale différence est la suivante : nous devons 🎜> Ajouter. un paramètre supplémentaire au début pour spécifier la direction du dégradé. Dans le code à rayures horizontales, nous pouvons en fait ajouter ce paramètre à
, mais sa valeur par défaut en bas est à l'origine cohérente avec notre intention
, il est donc omis. Enfin, nous devons également inverser la valeur de background-size
 :

background: linear-gradient(to right, #fb3 50%, #58a 0);
background-size: 30px 100%;
Il est à noter que si le premier paramètre de Linear-gradient est ajouté, sa direction par défaut changera. "de bas en haut". Pour cette raison, l'auteur a également envoyé un e-mail à Novice Tutorial et lui a suggéré de modifier le libellé du document.

Compréhension approfondie des compétences dutilisation de la propriété CSS *-gradient

倾斜条纹
“传统的”仅仅改变linear-gradient第一个参数——角度值的方式或者通过background-size增加“精确度”的方式都不能有效的达到真正意义上完美的倾斜背景:它们总是会在大小改变或者换一个倾斜度时把整个图案搞乱!
幸运的是,我们还有更好的方法来创建斜向条纹:一个鲜为人知的真相是 linear-gradient() 和 radial-gradient() 还各有一个循环式的加强版:repeating-linear-gradient() 和 repeating-radial-gradient()。
它们的工作方式跟前两者类似,只有一点不同:色标是无限循环重复的,直
到填满整个背景!

background: repeating-linear-gradient(45deg, #fb3, #58a 30px);

Compréhension approfondie des compétences dutilisation de la propriété CSS *-gradient
哦,对了,同上面一样,所有的“-gradient”属性在没有限制起始位置和终止位置时都会有“渐变光晕”,如果我们改为下面这样:

background: repeating-linear-gradient(60deg, #fb3 0 15px, #58a 0 30px);

Compréhension approfondie des compétences dutilisation de la propriété CSS *-gradient

看到这张图你有没有想到一个著名的案例——三角形?

background: #eee;
background-image: linear-gradient(45deg, transparent 75%, #bbb 0);

而我们以前用CSS一般是像这样写的:

width: 0;
height: 0;
border: 50px solid transparent;
border-top-color: black ;

其实,linear-gradient用处还远远不止这些…


2020-10-17更新

radial-gradient及整体应用

我们大概都知道:滚动条是一种常见的界面控件,用来提示一个元素除了可以看到的内容之外,还包含了更多内容。但是,它往往太过笨重,在视觉上喧宾夺主,因此现代操作系统已经开始简化它的外观,当用户不与可滚动的元素交互时,滚动条就会被完全隐藏。
目前已知的“去除滚动条”的方法中,最常用的有:::-webkit-scrollbar{display:none;} ,但是很显然,IE上无法使用 —— 它只允许改变滚动块的颜色。

在CSS3的时代,我们可以在想要加滚动条的地方外包裹一层p,为其设置overflow:hidden,内部用calc()函数动态计算width使其溢出!这可以有效解决IE下兼容性问题。

我们现在已经很少通过滚动条来滚动页面了(更多的是使用触摸手势),但滚动条对于元素内容可滚动的提示作用仍然是十分有用的,哪怕对于那些没有发生交互的元素也是如此;而且这种提示方式十分巧妙。
据说曾经 Google 推出了一款 RSS 阅读器(已经没了),它的用户体验设计师找到了一种非常优雅的方式来作出类似的提示:当侧边栏的容器还有更多内容时,一层淡淡的阴影会出现在容器的顶部和底部。就像这样:
Compréhension approfondie des compétences dutilisation de la propriété CSS *-gradient

让我们首先从一段简单的结构代码开始,一个带有示意性内容的普通无序列表:


  • Ada Catlace
  • Alan Purring
  • Schrödingcat
  • Tim Purrners-Lee
  • WebKitty
  • Json
  • Void
  • Neko
  • NaN
  • Cat5
  • Vector
  • Ada Catlace
  • Alan Purring
  • Schrödingcat
  • Tim Purrners-Lee
  • WebKitty
  • Json
  • Void
  • Neko
  • NaN
  • Cat5
  • Vector
  • Ada Catlace
  • Alan Purring
  • Schrödingcat
  • Tim Purrners-Lee
  • WebKitty
  • Json
  • Void
  • Neko
  • NaN
  • Cat5
  • Vector
  • Ada Catlace
  • Alan Purring
  • Schrödingcat
  • Tim Purrners-Lee
  • WebKitty
  • Json
  • Void
  • Neko
  • NaN
  • Cat5
  • Vector

我们可以给 <ul></ul> 元素设置一些基本的样式,让它的高度略短于内容,从而让其内容可以滚动:

overflow: auto;
width: 10em;
height: 8em;
padding: .3em .5em;
border: 1px solid silver;

接下来,有趣的事情即将发生。我们用一个径向渐变在顶部添加一条阴影:

background: radial-gradient(at top, rgba(0,0,0,.2),transparent 70%) no-repeat;
background-size: 100% 15px;

现在,当我们滚动列表时,这条阴影会一直停留在相同的位置。这正是背景图像的默认行为:它的位置是相对于元素固定的!不论元素的内容是否发生了滚动。这一点也适用于 background-attachment: fixed 的背景图像。它们唯一的区别是,当页面滚动时,后者是相对于视口固定的。有没有办法让背景图像跟着元素的内容一起滚动呢?

现在常见的值只有inheritscrollfixed,但是从W3C文档中可以看到:后来为background-attachment 属性增加了一个新的关键字,叫作 local
如果将此属性应用到这条阴影上,它会带给我们正好相反的效果:当我们滚动到最顶端时,能看到一条阴影;但当我们向下滚动时,这条阴影就消失了。

但这不重要,我们的思路对了!

我想到了一个很常用的hack:我们需要两层背景:一层用来生成那条阴影,另一层基本上就是一个用来遮挡阴影的白色矩形,其作用类似于遮罩层。生成阴影的那层背景将具有默认的 background-attachment 值(scroll),因为我们希望它总是保持在原位。我们把遮罩背景的 background-attachment 属性设置为 local,这样它就会在我们滚动到最顶部时盖住阴影,在向下滚动时跟着滚动,从而露出阴影。

background: linear-gradient(white 30%, transparent),
 			radial-gradient(at 50% 0, rgba(0,0,0,.2),transparent 70%);
background-repeat: no-repeat;
background-size: 100% 50px, 100% 15px;
background-attachment: local, scroll;

没错,这就是linear-gradient的另一个应用 —— 渐变遮罩层!

但是现在我们会发现:现在只有上边有,下边怎么搞?
这就需要用到css中的“简写”以及对*-gradient的理解了:如果不加第一个参数(不指明方向),则默认是从上到下渐变的,但是如果加了第一个参数但是没有指明to bottom100%,那么它默认是从下向上渐变的!

background: linear-gradient(white 30%, transparent) top / 100% 50px,
	radial-gradient(at 50% 0, rgba(0,0,0,.2),transparent 72%) top / 100% 15px,
	linear-gradient(to top, white 15px, hsla(0,0%,100%,0)) bottom / 100% 50px,
 	radial-gradient(at bottom, rgba(0,0,0,.2), transparent 72%) bottom / 100% 15px;
background-repeat: no-repeat;
background-attachment: local, scroll,local, scroll;

更多编程相关知识,请访问:编程视频!!

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer
Article précédent:Quelle est la priorité CSSArticle suivant:Quelle est la priorité CSS