" 2 . Melalui kawalan dinamik Perubahan keadaan mengubah gaya elemen 3. Dengan menggunakan kod JS dalam DOM, peralihan paparan dan penyembunyian DOM yang berbeza direalisasikan."/> " 2 . Melalui kawalan dinamik Perubahan keadaan mengubah gaya elemen 3. Dengan menggunakan kod JS dalam DOM, peralihan paparan dan penyembunyian DOM yang berbeza direalisasikan.">

Rumah  >  Artikel  >  hujung hadapan web  >  Cara mengubah suai gaya secara dinamik dalam bertindak balas

Cara mengubah suai gaya secara dinamik dalam bertindak balas

藏色散人
藏色散人asal
2022-12-28 10:44:144649semak imbas

Cara mengubah suai gaya secara dinamik dalam React: 1. Tambahkan ref pada elemen yang gayanya perlu diubah suai, dengan sintaks seperti "

Cara mengubah suai gaya secara dinamik dalam bertindak balas

Persekitaran pengendalian tutorial ini: Sistem Windows 10, bertindak balas versi 18.0.0, komputer Dell G3.

Bagaimana untuk mengubah suai gaya secara dinamik dalam bertindak balas?

Kira-kira tiga cara untuk mengubah suai gaya elemen secara dinamik dalam React

Bertindak balas untuk mengubah suai gaya elemen secara dinamik

Cara biasa untuk mengubah suai gaya elemen secara dinamik dalam React Terdapat dua jenis: mengubah suai gaya elemen dengan bantuan ref dan mengawal perubahan keadaan secara dinamik

1 Mengubah suai gaya secara dinamik dengan bantuan ref

Tambah ref

<div className=&#39;scroll-title clear-fix&#39; ref={ this.manage }>
Tambah React.createRef() dalam pembina

this.manage = React.createRef()
Gunakan dalam logik. kod

this.manage.current.style.display = &#39;block&#39;
Jika ini tidak dapat dikenali dalam kod, anda perlu menukar penunjuk ini melalui let that = this

that.manage.current.style.display = &#39;block&#39;
2. Ubah suai gaya elemen melalui kawalan dinamik perubahan keadaan ( Dua cara)

Kaedah 1

Tetapkan paparan bendera dalam kod logik kepada menjadi benar secara lalai, dan tukar nilai paparan kepada benar atau salah melalui syarat yang sepadan, kemudian Berikan nama gaya yang sepadan kepada atribut className DOM Gaya ditulis dalam gaya yang sepadan

. Contohnya:

 constructor() {
        super()
        this.state = {
            display: true
        }
    }   
    componentDidMount() {
        window.onscroll = function(event) {
                if (divTop < -12) {
                     that.setState({
                         display: false
                     })
                    that.manage.current.style.display = &#39;block&#39;
                } else {
                     that.setState({
                         display: true
                     })
                }
        }
    }
<div className={this.state.display ? &#39;none&#39; : &#39;scroll-title }>

Kaedah 2

Prinsip kaedah 2 adalah sama seperti kaedah 1. Tetapkan paparan bit bendera dalam kod logik menjadi benar secara lalai, dan tukar nilai paparan kepada benar atau melalui syarat yang sepadan palsu, dan kemudian tetapkan nama gaya yang sepadan kepada atribut className DOM, dan gaya ditulis dalam gaya yang sepadan. Perbezaannya ialah kod logik tidak dinilai dalam DOM, tetapi dalam js, seperti berikut:

Cara mengubah suai gaya secara dinamik dalam bertindak balas

3 menggunakan kod JS (operator ternari) dalam DOM

untuk mencapai paparan dan paparan DOM berbeza Transformasi tersembunyi

Kaedah 3 bukanlah perubahan dalam gaya dalam erti kata yang ketat, ia hanya digunakan untuk menukar paparan, penyembunyian dan paparan komponen yang sepadan

Cara mengubah suai gaya secara dinamik dalam bertindak balas

Untuk meringkaskan:

    Jika terdapat banyak gaya diubah dan pelbagai, gunakan 2
  • Jika tidak terlalu banyak gaya diubah, gunakan 1 dan 2
  • Jika ia hanya bertukar (menunjukkan dan menyembunyikan ) antara dua komponen, adalah paling mudah untuk menggunakan 3
Masalah konflik gaya tindak balas

Sudah ada konfigurasi sass dalam perancah tindak balas, jadi hanya Jika anda perlu memasang pakej dependency sass, anda boleh menggunakan sass terus

Pasang pakej dependency sass

npm i sass -D
- Tukar index.css Ke index.scss

- Import fail index.scss

Nota: Jika scss digunakan, apabila menggunakan laluan mutlak imej dalam scss, anda perlu menambah~

background-image: url(~assets/login.png);
penswastaan ​​gaya css

modul css-penggunaan asas

Langkah

Tukar nama fail gaya. Daripada xx.scss -> xx.module.scss (konvensyen dalam perancah React, dibezakan daripada CSS biasa)

2.

    Import fail gaya ke dalam komponen (perhatikan sintaks)
import styles from &#39;./index.module.scss&#39;
    Akses nama gaya dalam objek melalui objek gaya Tetapkan gaya
<div className={styles.css类名}></div>
nama kelas css ialah nama kelas yang ditakrifkan dalam index.module.scss.

Contoh

Tentukan style index.module.css

.root {font-size: 100px;}

Menggunakan gaya

import styles from &#39;./index.module.css&#39;
<div className={styles.root}>div的内容</div>

Prinsip

Modul CSS melengkapkan secara automatik nama kelas kepada nama kelas CSS untuk memastikan bahawa nama kelas adalah betul Keunikan, dengan itu mengelakkan masalah konflik gaya

Nota pada modul css

Sebaik-baiknya menggunakan penamaan kes unta untuk nama kelas, kerana yang terakhir nama kelas akan menghasilkan atribut gaya

cssModules-Maintain nama kelas

Format

Dalam xxx.module.scss, jika anda ingin mengekalkan nama kelas, anda boleh menggunakan format:

:global(.class name)

/*这样css modules就不会修改掉类名.a了。等价于写在 index.css中 */
:global(.a) {   }
 
/* 这样css modules就不会修改掉类名.a了, 但是 .aa还是会被修改 */
.aa :golbal(.a) { }
Timpa gaya komponen pihak ketiga

:global(.ant-btn) {
  color: red !important;
}
modul css- Amalan Terbaik

- Gunakan nama kelas dalam bentuk CSSModules untuk nod akar setiap komponen (nama kelas elemen akar: root )

- Gunakan kelas CSS biasa untuk semua nod anak lain Nama: global

index.module.scss

// index.module.scss
.root {
  display: &#39;block&#39;;
  position: &#39;absolute&#39;;
  // 此处,使用 global 包裹其他子节点的类名。此时,这些类名就不会被处理,在 JSX 中使用时,就可以用字符串形式的类名
  // 如果不加 :global ,所有类名就必须添加 styles.title 才可以
  :global {
    .title {
      .text {
      }
      span {
      }
    }
    .login-form { ... }
  }
}
penggunaan komponen

import styles from &#39;./index.module.scss&#39;
const 组件 = () => {
  return (
    {/* (1) 根节点使用 CSSModules 形式的类名( 根元素的类名: `root` )*/}
      
{/* (2) 所有子节点,都使用普通的 CSS 类名*/}

登录 登录

) }

Pembelajaran yang disyorkan: "tutorial video bertindak balas"

Atas ialah kandungan terperinci Cara mengubah suai gaya secara dinamik dalam bertindak balas. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn