πŸ”

Бтилизация select Π½Π° чистом CSS

Бтилизация select Π½Π° чистом CSS

Π― Π΄Π°Π½Π½ΠΎΠΉ ΡΡ‚Π°Ρ‚ΡŒΠ΅ я Ρ…ΠΎΡ‡Ρƒ Ρ€Π°ΡΡΠΊΠ°Π·Π°Ρ‚ΡŒ ΠΎ стилизации select Π½Π° чистом CSS для Chrome, Safari, Firefox ΠΈ IE9+ Π±Π΅Π· добавлСния Π΄ΠΎΠΏΠΎΠ»Π½ΠΈΡ‚Π΅Π»ΡŒΠ½Ρ‹Ρ… элСмСнтов.

Π’ΠΎΡ‚ вСсь css ΠΊΠΎΠ΄:

select {
    width: 160px;
    height: 26px;
    border-radius: 4px;
    line-height: 1em;

    background-image: url('/select-arrow.svg');
    background-position: right center;
    background-repeat: no-repeat;

    /*for WebKit*/
    -webkit-appearance: none;
    /* for FF */
    -moz-appearance: none;
    text-indent: 0.01px; 
    text-overflow: '';
    /* for IE */
    -ms-appearance: none;
    appearance: none !important;
}
 
select::-ms-expand {
    display: none;
}

Π’Π΅ΠΏΠ΅Ρ€ΡŒ Π΄Π°Π²Π°ΠΉΡ‚Π΅ Ρ€Π°Π·Π±Π΅Ρ€Ρ‘ΠΌ Π΅Π³ΠΎ для ΠΏΠΎΠ»Π½ΠΎΠ³ΠΎ понимания Ρ‡Ρ‚ΠΎ происходит.

ΠŸΠ΅Ρ€Π²Π°Ρ Ρ‡Π°ΡΡ‚ΡŒ ΠΊΠΎΠ΄Π° ΠΎΡ‚Π²Π΅Ρ‡Π°Π΅Ρ‚ Π·Π° Π±Π°Π·ΠΎΠ²ΡƒΡŽ ΡΡ‚ΠΈΠ»ΠΈΠ·Π°Ρ†ΠΈΡŽ элСмСнта. МоТно Ρ‚Π°ΠΊΠΆΠ΅ Π΄ΠΎΠ±Π°Π²ΠΈΡ‚ΡŒ Ρ†Π²Π΅Ρ‚ Ρ„ΠΎΠ½Π° background-color ΠΈ Ρ†Π²Π΅Ρ‚ border.

width: 160px;
height: 26px;
border-radius: 4px;
line-height: 1em;

Π”Π°Π»Π΅Π΅ отмСняСм стандартноС ΠΎΡ‚ΠΎΠ±Ρ€Π°ΠΆΠ΅Π½ΠΈΠ΅ select:

/*for WebKit*/
-webkit-appearance: none;
/* for FF */
-moz-appearance: none;
text-indent: 0.01px; 
text-overflow: '';
/* for IE */
-ms-appearance: none;
appearance: none !important;

Π’Π΅ΠΏΠ΅Ρ€ΡŒ Π·Π°Π΄Π°Π΅ΠΌ Π²ΠΈΠ΄ стрСлки, которая присутствуСт Π² ΠΊΠ°ΠΆΠ΄ΠΎΠΌ select. Π€ΠΎΠ½ Π·Π°Π΄Π°Π½ ΠΎΡ‚Π΄Π΅Π»ΡŒΠ½Ρ‹ΠΌΠΈ свойствами, Ρ‡Ρ‚ΠΎΠ±Ρ‹ ΠΌΠΎΠΆΠ½ΠΎ Π±Ρ‹Π»ΠΎ Π΄ΠΎΠ±Π°Π²ΠΈΡ‚ΡŒ Ρ„ΠΎΠ½ΠΎΠ²Ρ‹ΠΉ Ρ†Π²Π΅Ρ‚ ΠΈ Π½Π΅ Π±ΠΎΡΡ‚ΡŒΡΡ, Ρ‡Ρ‚ΠΎ ΠΎΠ½ ΠΏΠ΅Ρ€Π΅ΠΊΡ€ΠΎΠ΅Ρ‚ ΠΊΠ°Ρ€Ρ‚ΠΈΠ½ΠΊΡƒ.

background-image: url('/select-arrow.svg');
background-position: right center;
background-repeat: no-repeat;

И ΠΎΡΡ‚Π°Π»ΠΎΡΡŒ малСнькоС Π΄ΠΎΠΏΠΎΠ»Π½Π΅Π½ΠΈΠ΅ для IE:

select::-ms-expand {
    display: none;
}

Π§ΠΈΡ‚Π°Ρ‚ΡŒ Π΅Ρ‰Ρ‘:

← React 18. createRoot

React 18. createRoot

Π§Ρ‚ΠΎ Ρ‚Π°ΠΊΠΎΠ΅ Nullish Coalescing β†’

Π§Ρ‚ΠΎ Ρ‚Π°ΠΊΠΎΠ΅ Nullish Coalescing