Table des matières
1 Pseudo élément +transform:translateX(. -100 %);
2. Pseudo élément + flex
3. Pseudo-element+box-shadow/outline+clip-path
L'idée principale est de définir le parent
8.fieldset+legend
小结
Maison interface Web tutoriel CSS Comment implémenter des diviseurs adaptatifs en CSS ? Présentation de la méthode

Comment implémenter des diviseurs adaptatifs en CSS ? Présentation de la méthode

Oct 28, 2020 pm 05:53 PM
css

Comment implémenter des diviseurs adaptatifs en CSS ? Présentation de la méthode

Comment implémenter des diviseurs adaptatifs en CSS ? La colonne CSS suivante vous présentera N façons d'implémenter des diviseurs adaptatifs en CSS. 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.

(Tutoriel recommandé : Tutoriel CSS)

La ligne de démarcation est un type courant de conception dans les pages Web, par exemple, plus Plus réponses

Comment implémenter des diviseurs adaptatifs en CSS ? Présentation de la méthode

Adaptatif signifie ici que les lignes horizontales de part et d'autre s'adapteront en fonction du nombre de texte et de la largeur du parent

Jetez un œil en secret Après avoir regardé l'implémentation sur Zhihu, il est évident qu'il est recouvert d'un fond blanc. L'ajout d'un petit fond révèle le secret

Comment implémenter des diviseurs adaptatifs en CSS ? Présentation de la méthode

Je pensais. : Le front-end de Zhihu n'est-il pas si bon ? Peut-être que d'autres ne se concentrent pas sur ces choses

Voici quelques meilleures méthodes de mise en œuvre, du genre qui ne révéleront pas la vérité

1 Pseudo élément +transform:translateX(. -100 %);

Le principe principal est de centrer le texte text-align: center;, puis étant donné deux pseudo-éléments, qui sont respectivement positionnés de manière absolue, alors les pseudo-éléments suivront également le centrage horizontal, définissez Assez de largeur, puis déplacez celui de gauche vers la gauche 100% N'oubliez pas de masquer le parent.

L'implémentation spécifique est la suivante

htmlLa structure est

<div class="title">我是分割线</div>
Copier après la connexion
Copier après la connexion
Copier après la connexion

cssLe style est

.title{
    position: relative;
    text-align: center;
    overflow: hidden;
    font-size: 14px;
    color: #999;
}
.title::before,.title::after{
    content: &#39;&#39;;
    display: inline-block;
    width: 100%;
    height: 1px;
    position: absolute;
    background: #ccc;
    top: 50%;
}
.title::before{
    margin-left: -10px;
    transform: translateX(-100%);
}
.title::after{
    margin-left: 10px;
}
Copier après la connexion

Séparateur CSS ( pseudo élément + transformation )

2. Pseudo élément + flex

C'est plus facile à comprendre Set display:flex, puis les deux pseudo éléments remplissent l'espace restant.

L'implémentation spécifique est la suivante

htmlLa structure est

<div class="title">我是分割线</div>
Copier après la connexion
Copier après la connexion
Copier après la connexion

cssLe style est

.title{
    display: flex;
    align-items: center;
    font-size: 14px;
    color: #999;
}
.title::before,.title::after{
    content: &#39;&#39;;
    flex: 1;
    height: 1px;
    background: #ccc;
}
.title::before{
    margin-right: 10px;
}
.title::after{
    margin-left: 10px;
}
Copier après la connexion

Séparateur CSS ( pseudo élément + flex )

3. Pseudo-element+box-shadow/outline+clip-path

Utilisez également text-align: center pour centrer le texte et le pseudo-élément, et puis générez un box-shadow Ou outline suffisamment grand, puisqu'une seule direction n'est pas prise en charge, utilisez clip-path ou clip pour recadrer

La structure spécifique de <. 🎜>

est html

<div class="title">我是分割线</div>
Copier après la connexion
Copier après la connexion
Copier après la connexion

Le style est css

.title{
    text-align: center;
    font-size: 14px;
    color: #999;
    overflow: hidden;
}
.title::before,.title::after{
    content: &#39;&#39;;
    display: inline-block;
    width: 0;
    height: 1px;
    box-shadow: 0 0 0 9999px #ccc;
    vertical-align: middle;
}
.title::before{
    margin-right: 10px;
    clip-path: polygon(0 0, -9999px 0, -9999px 100%, 0 100%);
}
.title::after{
    margin-left: 10px;
    clip-path: polygon(0 0, 9999px 0, 9999px 100%, 0 100%);
}
Copier après la connexion

Diviseur CSS (pseudo-élément+box-shadow/outline+clip-path)

4. Pseudo-élément +right:100%

Cette implémentation nécessite une couche supplémentaire de balises. La partie externe est toujours

, et deux pseudo-éléments sont ajoutés. le texte intérieur pour un positionnement absolu. Celui de gauche est réglé à 100 % à partir de la droite (par rapport à la balise de texte) text-align: center

L'implémentation spécifique est la suivante

La structure est html

<div class="title">
   <span class="inner">我是分割线</span>
</div>
Copier après la connexion

Le style est css

.title{
    text-align: center;
    font-size: 14px;
    color: #999;
    overflow: hidden;
}
.inner{
    position: relative;
}
.inner::before,.inner::after{
    position: absolute;
    content: &#39;&#39;;
    width: 9999px;
    height: 1px;
    background: #ccc;
    top: 50%;
}
.inner::before{
    right: 100%;
    margin-right: 10px;
}
.inner::after{
    margin-left: 10px;
}
Copier après la connexion

Séparateur CSS (pseudo élément +droite : 100%)

bordure+transformation

Cette idée ne nécessite pas de pseudo-éléments, mais elle nécessite des balises supplémentaires pour donner au texte interne des

bordures suffisamment grandes sur les côtés gauche et droit, ce qui est nécessaire à ce moment-là. Définir 1px Puisque l'ensemble interne est. assez grand (plus que le parent), vous pouvez utiliser le positionnement absolu et le line-height:1pxcentrage transform: translateX(-50%)

L'implémentation spécifique est la suivante La structure

est html Le style. de

<div class="title">
    <span class="inner">我是分割线</span>
</div>
Copier après la connexion
Copier après la connexion
Copier après la connexion

est css

.title{
    position: relative;
    text-align: center;
    font-size: 14px;
    color: #999;
    overflow: hidden;
    padding: .6em 0;/**把高度撑起来**/
}
.inner{
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    line-height: 1px;
    border-left: 9999px solid #ccc;
    border-right: 9999px solid #ccc;
    padding: 0 10px;
}
Copier après la connexion

Séparateur CSS (bordure+transformation)

6. Pseudo-élément + bordure+gauche/droite

Cette idée ne nécessite qu'un seul pseudo élément, générer un pseudo élément à l'intérieur du texte, et utiliser un

suffisamment grand et la même valeur négative (positionnement absolu + gauche/droite) pour restaurer la position border

. l'implémentation spécifique est la suivante< La structure de 🎜>

est

<div class="title">
    <span class="inner">我是分割线</span>
</div>
Copier après la connexion
Copier après la connexion
Copier après la connexion
html

et le style est

.title{
    text-align: center;
    font-size: 14px;
    color: #999;
    overflow: hidden;
}
.inner{
    position: relative;
    padding: 0 10px;
}
.inner::before{
    content: &#39;&#39;;
    position: absolute;
    height: 1px;
    top: 50%;
    border-left: 9999px solid #ccc;
    border-right: 9999px solid #ccc;
    right: -9999px;
    left: -9999px;
}
Copier après la connexion
css

Diviseur CSS (pseudo élément+bordure+ gauche/droite)

7. Pseudo-élément + cellule de table

L'idée principale est de définir le parent

, de définir le pseudo-élément

et de définir un largeur assez grandedisplay:tabledisplay:table-cellSpécifique La mise en œuvre est la suivante :

La structure est

<div class="title">
    <span class="inner">我是分割线</span>
</div>
Copier après la connexion
Copier après la connexion
Copier après la connexion
html

Le style est

.title{
    display: table;
    font-size: 14px;
    color: #999;
}
.inner{
    display: table-cell;
    white-space: nowrap;
    padding: 0 10px;
}
.title::before,.title::after{
    content: &#39;&#39;;
    display: table-cell;
    width: 9999px;
    overflow: hidden;
    background: linear-gradient(#ccc 0,#ccc) center no-repeat;/**这里用线性渐变生成的,也可以用其他方式**/
    background-size: 100% 1px;
}
Copier après la connexion
css

Séparateur CSS (pseudo-élément + cellule-tableau)

8.fieldset+legend

利用fieldsetlegend标签组合,可以天然实现分隔线效果,参考至张鑫旭的这篇文章

具体实现如下

html结构为

<fieldset class="title">
    <legend class="inner">我是分割线</legend>
</fieldset>
Copier après la connexion

css样式为

.title{
    font-size: 14px;
    color: #999;
    border: 0;
    border-top: 1px solid #ccc;
    padding: 0;
}
.inner{
    margin: 0 auto;;
    padding: 0 10px;
}
Copier après la connexion

CSS分隔线 (fieldset+legend)

小结

上面一共列举了8中方式来实现分隔线的效果,每种方法思路各不相同,重要的是可以发散自己的想象力,可能这才是CSS与其他语言所不同的吧~

这里整理了一下,整体效果如下,可访问这里查看,大家在实际项目中可自行选取所需要的方式

Comment implémenter des diviseurs adaptatifs en CSS ? Présentation de la méthode

可能还有其他方式没有想到,欢迎大家集思广益,在下方留言讨论

更多编程相关知识,请访问:编程入门!!

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 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)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois 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)

Comment écrire des lignes fendues sur bootstrap Comment écrire des lignes fendues sur bootstrap Apr 07, 2025 pm 03:12 PM

Il existe deux façons de créer une ligne divisée bootstrap: en utilisant la balise, qui crée une ligne divisée horizontale. Utilisez la propriété CSS Border pour créer des lignes de fractionnement de style personnalisées.

Comment insérer des photos sur bootstrap Comment insérer des photos sur bootstrap Apr 07, 2025 pm 03:30 PM

Il existe plusieurs façons d'insérer des images dans Bootstrap: insérer directement les images, en utilisant la balise HTML IMG. Avec le composant d'image bootstrap, vous pouvez fournir des images réactives et plus de styles. Définissez la taille de l'image, utilisez la classe IMG-FLUID pour rendre l'image adaptable. Réglez la bordure en utilisant la classe IMG-border. Réglez les coins arrondis et utilisez la classe Roundée IMG. Réglez l'ombre, utilisez la classe Shadow. Redimensionner et positionner l'image, en utilisant le style CSS. À l'aide de l'image d'arrière-plan, utilisez la propriété CSS d'image d'arrière-plan.

Comment redimensionner le bootstrap Comment redimensionner le bootstrap Apr 07, 2025 pm 03:18 PM

Pour ajuster la taille des éléments dans Bootstrap, vous pouvez utiliser la classe de dimension, qui comprend: ajuster la largeur: .col-, .w-, .mw-ajustement Hauteur: .h-, .min-h-, .max-h-

Comment configurer le cadre de bootstrap Comment configurer le cadre de bootstrap Apr 07, 2025 pm 03:27 PM

Pour configurer le framework Bootstrap, vous devez suivre ces étapes: 1. Référez le fichier bootstrap via CDN; 2. Téléchargez et hébergez le fichier sur votre propre serveur; 3. Incluez le fichier bootstrap dans HTML; 4. Compiler les sass / moins au besoin; 5. Importer un fichier personnalisé (facultatif). Une fois la configuration terminée, vous pouvez utiliser les systèmes, composants et styles de grille de Bootstrap pour créer des sites Web et des applications réactifs.

Les rôles de HTML, CSS et JavaScript: responsabilités de base Les rôles de HTML, CSS et JavaScript: responsabilités de base Apr 08, 2025 pm 07:05 PM

HTML définit la structure Web, CSS est responsable du style et de la mise en page, et JavaScript donne une interaction dynamique. Les trois exercent leurs fonctions dans le développement Web et construisent conjointement un site Web coloré.

Comment utiliser le bouton bootstrap Comment utiliser le bouton bootstrap Apr 07, 2025 pm 03:09 PM

Comment utiliser le bouton bootstrap? Introduisez Bootstrap CSS pour créer des éléments de bouton et ajoutez la classe de bouton bootstrap pour ajouter du texte du bouton

Comment utiliser Bootstrap en Vue Comment utiliser Bootstrap en Vue Apr 07, 2025 pm 11:33 PM

L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

Comment afficher la date de bootstrap Comment afficher la date de bootstrap Apr 07, 2025 pm 03:03 PM

Réponse: Vous pouvez utiliser le composant de sélecteur de date de bootstrap pour afficher les dates dans la page. Étapes: Présentez le framework bootstrap. Créez une boîte d'entrée de sélecteur de date dans HTML. Bootstrap ajoutera automatiquement des styles au sélecteur. Utilisez JavaScript pour obtenir la date sélectionnée.

See all articles