In diesem Artikel wird hauptsächlich die reine CSS-Implementierung zum Festlegen des Stils eines halben Zeichens, zum Erzielen horizontaler und vertikaler halber, horizontaler und vertikaler dritter Effekte usw. vorgestellt. Freunde in Not können sich auf
unter „Ich habe eins gesehen“ beziehen Frage zu Stackoverflow, wie man Stile für ein halbes Zeichen festlegt, und viele Experten gaben Antworten. Ich werde einfach abwarten und lernen und zuschauen.
1: Grundlösung: html:
<span class=”halfStyle” data-content=”X”>X</span> <span class=”halfStyle” data-content=”Y”>Y</span> <span class=”halfStyle” data-content=”Z”>Z</span> <span class=”halfStyle” data-content=”A”>A</span>
css:
.halfStyle { position:relative; display:inline-block; font-size:80px; /* or any font size will work */ color: black; /* or transparent, any color */ overflow:hidden; white-space: pre; /* to preserve the spaces from collapsing */ } .halfStyle:before { display:block; z-index:1; position:absolute; top:0; left:0; width: 50%; content: attr(data-content); /* dynamic content for the pseudo element */ overflow:hidden; color: #f00; }
Der Effekt ist wie gezeigt:
Diese Methode funktioniert mit jedem dynamischen Text oder einzelnen Zeichen und ist automatisch anwendbar. Sie müssen lediglich eine Klasse zum Zieltext hinzufügen und der Rest wird erledigt.
Gleichzeitig bleibt die Zugänglichkeit des Originaltextes erhalten und kann von Screenreadern blinder oder sehbehinderter Menschen erkannt werden.
Einzelzeichenimplementierung:
Reines CSS. Sie müssen lediglich die Klasse .halfStyle auf jedes Element anwenden, das die Hälfte der Stilzeichen rendern soll.
Für jedes span-Element, das Zeichen enthält, können Sie ein Datenattribut hinzufügen, z. B. data-content="X", und content:attr(data-content) für das Pseudoelement verwenden, also . halfStyle: Bevor die Klasse dynamisch ist, müssen Sie nicht jede Instanz fest codieren
Die folgenden anderen Effekte können Sie selbst testen. . .
Zweitens: Schleife links und rechts öffnen, Stile auf beiden Seiten festlegen
CSS ändern:
.halfStyle { position:relative; display:inline-block; font-size:80px; /* or any font size will work */ color: transparent; /* hide the base character */ overflow:hidden; white-space: pre; /* to preserve the spaces from collapsing */ } .halfStyle:before { /* creates the left part */ display:block; z-index:1; position:absolute; top:0; width: 50%; content: attr(data-content); /* dynamic content for the pseudo element */ overflow:hidden; pointer-events: none; /* so the base char is selectable by mouse */ color: #f00; /* for demo purposes */ text-shadow: 2px -2px 0px #af0; /* for demo purposes */ } .halfStyle:after { /* creates the right part */ display:block; direction: rtl; /* very important, will make the width to start from right */ position:absolute; z-index:2; top:0; left:50%; width: 50%; content: attr(data-content); /* dynamic content for the pseudo element */ overflow:hidden; pointer-events: none; /* so the base char is selectable by mouse */ color: #000; /* for demo purposes */ text-shadow: 2px 2px 0px #0af; /* for demo purposes */ }
Drei: Stil festlegen der horizontalen Hälfte
CSS:
.halfStyle { position:relative; display:inline-block; font-size:80px; /* or any font size will work */ color: transparent; /* hide the base character */ overflow:hidden; white-space: pre; /* to preserve the spaces from collapsing */ } .halfStyle:before { /* creates the top part */ display:block; z-index:2; position:absolute; top:0; height: 50%; content: attr(data-content); /* dynamic content for the pseudo element */ overflow:hidden; pointer-events: none; /* so the base char is selectable by mouse */ color: #f00; /* for demo purposes */ text-shadow: 2px -2px 0px #af0; /* for demo purposes */ } .halfStyle:after { /* creates the bottom part */ display:block; position:absolute; z-index:1; top:0; height: 100%; content: attr(data-content); /* dynamic content for the pseudo element */ overflow:hidden; pointer-events: none; /* so the base char is selectable by mouse */ color: #000; /* for demo purposes */ text-shadow: 2px 2px 0px #0af; /* for demo purposes */ }
Vier: Horizontaler dritter Stil
css:
.halfStyle { /* base char and also the bottom 1/3 */ position:relative; display:inline-block; font-size:80px; /* or any font size will work */ color: transparent; overflow:hidden; white-space: pre; /* to preserve the spaces from collapsing */ color: #f0f; text-shadow: 2px 2px 0px #0af; /* for demo purposes */ } .halfStyle:before { /* creates the top 1/3 */ display:block; z-index:2; position:absolute; top:0; height: 33.33%; content: attr(data-content); /* dynamic content for the pseudo element */ overflow:hidden; pointer-events: none; /* so the base char is selectable by mouse */ color: #f00; /* for demo purposes */ text-shadow: 2px -2px 0px #fa0; /* for demo purposes */ } .halfStyle:after { /* creates the middle 1/3 */ display:block; position:absolute; z-index:1; top:0; height: 66.66%; content: attr(data-content); /* dynamic content for the pseudo element */ overflow:hidden; pointer-events: none; /* so the base char is selectable by mouse */ color: #000; /* for demo purposes */ text-shadow: 2px 2px 0px #af0; /* for demo purposes */ }
Fünf: Vertikaler Drei-Drittel-Stil
css:
.halfStyle { /* base char and also the right 1/3 */ position:relative; display:inline-block; font-size:80px; /* or any font size will work */ color: transparent; /* hide the base character */ overflow:hidden; white-space: pre; /* to preserve the spaces from collapsing */ color: #f0f; /* for demo purposes */ text-shadow: 2px 2px 0px #0af; /* for demo purposes */ } .halfStyle:before { /* creates the left 1/3 */ display:block; z-index:2; position:absolute; top:0; width: 33.33%; content: attr(data-content); /* dynamic content for the pseudo element */ overflow:hidden; pointer-events: none; /* so the base char is selectable by mouse */ color: #f00; /* for demo purposes */ text-shadow: 2px -2px 0px #af0; /* for demo purposes */ } .halfStyle:after { /* creates the middle 1/3 */ display:block; z-index:1; position:absolute; top:0; width: 66.66%; content: attr(data-content); /* dynamic content for the pseudo element */ overflow:hidden; pointer-events: none; /* so the base char is selectable by mouse */ color: #000; /* for demo purposes */ text-shadow: 2px 2px 0px #af0; /* for demo purposes */ }
Das Obige ist der gesamte Inhalt dieses Artikels, der für das Lernen aller hilfreich sein wird Bitte achten Sie auf die chinesische PHP-Website!
Das obige ist der detaillierte Inhalt vonSo verwenden Sie CSS, um ein halbes Zeichen zu formatieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!