Rumah >hujung hadapan web >tutorial js >Mengapa Vue Saya Tidak Mengira Kemas Kini Harta Apabila Menggunakan Fungsi Anak Panah?

Mengapa Vue Saya Tidak Mengira Kemas Kini Harta Apabila Menggunakan Fungsi Anak Panah?

Susan Sarandon
Susan Sarandonasal
2024-11-29 03:05:10511semak imbas

Why Doesn't My Vue Computed Property Update When Using Arrow Functions?

Menggunakan Fungsi Anak Panah dalam Sifat Pengiraan Vue

Dalam Vue, fungsi anak panah boleh digunakan untuk menentukan sifat yang dikira. Walau bagaimanapun, pengguna mungkin menghadapi masalah di mana warna elemen pengiraan mereka tidak berubah apabila menggunakan fungsi anak panah.

Perbandingan Kod Asal dan Diubah Suai

Kod asal menggunakan sintaks fungsi tradisional untuk mentakrifkan sifat yang dikira:

computed: {
  switchRed: function() {
    return { red: this.turnRed };
  },
  switchGreen: function() {
    return { green: this.turnGreen };
  },
  switchBlue: function() {
    return { blue: this.turnBlue };
  }
}

Selepas mengubah suai kod untuk menggunakan fungsi anak panah, isu timbul:

computed: {
  switchRed: () => {
    return { red: this.turnRed };
  },
  switchGreen: () => {
    return { green: this.turnGreen };
  },
  switchBlue: () => {
    return { blue: this.turnBlue };
  }
}

Punca Punca

Masalahnya terletak pada penggunaan fungsi anak panah. Fungsi anak panah mewarisi konteks ini daripada induk, manakala sintaks fungsi tradisional mengikat ini kepada tika Vue. Apabila menggunakan fungsi anak panah dalam sifat yang dikira, ini tidak terikat pada tika Vue, yang membawa kepada kegagalan untuk mengemas kini warna elemen yang dikira.

Penyelesaian

Kepada menyelesaikan isu tersebut, adalah disyorkan untuk menggunakan sintaks fungsi tradisional untuk sifat yang dikira. Sebagai alternatif, seseorang boleh menggunakan fungsi anak panah untuk kaedah, tetapi penting untuk mengikat ini secara eksplisit pada tika Vue menggunakan kaedah bind atau gunakan.

Atas ialah kandungan terperinci Mengapa Vue Saya Tidak Mengira Kemas Kini Harta Apabila Menggunakan Fungsi Anak Panah?. 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