cari
Rumahhujung hadapan webSoal Jawab bahagian hadapanBeberapa cara untuk memanggil kaedah antara berbilang fail Vue

Dalam pembangunan Vue, kami biasanya menggunakan komponen fail tunggal (fail .vue) untuk pembangunan, memisahkan komponen untuk meningkatkan kebolehbacaan dan kebolehselenggaraan kod. Tetapi apabila memanggil kaedah antara berbilang komponen fail tunggal, beberapa masalah mungkin timbul. Artikel ini akan memperkenalkan beberapa cara untuk memanggil kaedah antara berbilang fail dalam Vue.

1. Gunakan Mixin (Mixin)

Mixin ialah kaedah yang sangat mudah yang disediakan oleh Vue, yang boleh merangkum beberapa kod biasa dan berkongsi antara berbilang komponen. Kita boleh menulis kaedah yang perlu dikongsi dalam Mixin dan memperkenalkan Mixin ini ke dalam komponen yang perlu menggunakan kaedah ini.

Sebagai contoh, kami mempunyai fail Mixin mixin.js, yang mengandungi kaedah showMsg:

export default {
  methods: {
    showMsg() {
      console.log('hello world')
    }
  }
}

Kami hanya perlu memperkenalkan mixin.js ke dalam komponen yang menggunakan kaedah showMsg.

import mixin from './mixin.js'

export default {
  mixins: [mixin],
  ...
}

Dalam kod di atas, kami memperkenalkan kod dalam mixin.js menggunakan atribut mixins dan menambahkannya pada komponen.

Dengan cara ini, anda boleh menggunakan kaedah showMsg dalam komponen.

this.showMsg()

2. Gunakan ini.$refs

Apabila kita mentakrifkan komponen dalam Vue, kita boleh menetapkan atribut ref kepadanya dan kita boleh merujuk contoh komponen ini dalam komponen. Rujukan ini boleh digunakan untuk memanggil kaedah komponen semasa.

Sebagai contoh, kita mempunyai dua komponen, komponen A dan komponen B. Komponen A memanggil kaedah dalam komponen B. Ini boleh dicapai melalui langkah berikut:

  1. Tetapkan ref atribut dalam komponen B.
<template>
  <div>
    组件B
  </div>
</template>

<script>
export default {
  methods: {
    methodOfB() {
      console.log(&#39;methodOfB&#39;)
    }
  }
}
</script>
<template>
  <div>
    <component-b></component-b>
  </div>
</template>

<script>
import ComponentB from &#39;./ComponentB.vue&#39;

export default {
  components: {ComponentB},
  methods: {
    methodOfA(){
      this.$refs.b.methodOfB()
    }
  }
}
</script>

Menggunakan ini.$refs.b dalam kaedah dalam komponen A boleh mendapatkan contoh komponen B, dengan itu menggunakan kaedah komponen B.

3. Gunakan vuex

Vuex ialah alat pengurusan negeri yang disediakan secara rasmi oleh Vue. Sangat mudah untuk berkongsi data antara berbilang komponen. Selain itu, kami juga boleh mentakrifkan beberapa kaedah awam dalam Vuex untuk digunakan oleh berbilang komponen.

Sebagai contoh, kami mempunyai fail store.js di mana kaedah awam ditakrifkan:

export default new Vuex.Store({
  state: {...},
  mutations: {...},
  actions: {...},
  getters: {...},
  methods: {
    showMsg() {
      console.log('hello world')
    }
  }
})

Dalam komponen yang perlu menggunakan kaedah awam ini, kami boleh menggunakan mapActions yang disediakan oleh Vuex Kaedah memetakan kaedah ini kepada komponen.

import { mapState, mapMutations, mapActions } from 'vuex'

computed: {
  ...mapState(['...']),
},
mutations: {
  ...mapMutations(['...']),
},
actions: {
  ...mapActions(['showMsg']),
}

Dengan cara ini anda boleh menggunakan kaedah showMsg dalam komponen.

4. Menggunakan EventBus

Kami boleh menggunakan EventBus milik Vue untuk berkomunikasi antara komponen, mengikat kaedah yang perlu dikongsi dengan EventBus dan komponen lain boleh menggunakan kaedah ini.

Sebagai contoh, kami mencipta EventBus dalam main.js:

import Vue from 'vue'

export const EventBus = new Vue()

Dalam komponen yang perlu menggunakan kaedah kongsi, kami boleh menggunakan kaedah EventBus.$on untuk mendengar acara untuk mendapatkan panggilan Messages untuk kaedah kongsi.

mounted(){
  EventBus.$on('showMsg', ()=>{this.showMsg()})
},

Dalam komponen dengan kaedah dikongsi, kita boleh menggunakan kaedah EventBus.$emit untuk mencetuskan acara showMsg.

EventBus.$emit('showMsg')

Ringkasan

Di atas ialah beberapa cara untuk memanggil kaedah antara berbilang fail dalam Vue. Melalui Mixin, ini.$refs, Vuex dan EventBus, kita boleh dengan mudah menyedari keperluan untuk berkongsi kaedah dalam berbilang komponen. Dalam perkembangan sebenar, kita boleh memilih kaedah yang sesuai dengan kita mengikut situasi sebenar.

Atas ialah kandungan terperinci Beberapa cara untuk memanggil kaedah antara berbilang fail Vue. 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
React Inside HTML: Mengintegrasikan JavaScript untuk laman web dinamikReact Inside HTML: Mengintegrasikan JavaScript untuk laman web dinamikApr 16, 2025 am 12:06 AM

Untuk mengintegrasikan React ke HTML, ikuti langkah -langkah ini: 1. Memperkenalkan React dan Reactdom dalam fail HTML. 2. Tentukan komponen React. 3. Mengadakan komponen ke dalam elemen HTML menggunakan ReactDom. Melalui langkah -langkah ini, halaman HTML statik dapat diubah menjadi pengalaman yang dinamik dan interaktif.

Faedah bertindak balas: prestasi, kebolehgunaan semula, dan banyak lagiFaedah bertindak balas: prestasi, kebolehgunaan semula, dan banyak lagiApr 15, 2025 am 12:05 AM

Populariti React termasuk pengoptimuman prestasi, penggunaan semula komponen dan ekosistem yang kaya. 1. Pengoptimuman prestasi mencapai kemas kini yang cekap melalui mekanisme maya dan mekanisme yang berbeza. 2. Penggunaan semula komponen mengurangkan kod pendua oleh komponen yang boleh diguna semula. 3. Ekosistem yang kaya dan aliran data sehala meningkatkan pengalaman pembangunan.

React: Membuat antara muka pengguna yang dinamik dan interaktifReact: Membuat antara muka pengguna yang dinamik dan interaktifApr 14, 2025 am 12:08 AM

React adalah alat pilihan untuk membina antara muka pengguna yang dinamik dan interaktif. 1) Komponen dan JSX membuat UI berpecah dan menggunakan semula mudah. 2) Pengurusan negeri dilaksanakan melalui cangkuk UseState untuk mencetuskan kemas kini UI. 3) Mekanisme pemprosesan acara bertindak balas terhadap interaksi pengguna dan meningkatkan pengalaman pengguna.

Rangka Kerja Backend: PerbandinganRangka Kerja Backend: PerbandinganApr 13, 2025 am 12:06 AM

React adalah rangka kerja front-end untuk membina antara muka pengguna; Rangka kerja back-end digunakan untuk membina aplikasi sisi pelayan. React menyediakan kemas kini UI yang komponen dan cekap, dan Rangka Kerja Backend menyediakan penyelesaian perkhidmatan backend lengkap. Apabila memilih timbunan teknologi, keperluan projek, kemahiran pasukan, dan skalabiliti harus dipertimbangkan.

HTML dan React: Hubungan antara markup dan komponenHTML dan React: Hubungan antara markup dan komponenApr 12, 2025 am 12:03 AM

Hubungan antara HTML dan React adalah teras pembangunan front-end, dan mereka bersama-sama membina antara muka pengguna aplikasi web moden. 1) HTML mentakrifkan struktur kandungan dan semantik, dan React membina antara muka dinamik melalui komponenisasi. 2) Komponen React Gunakan sintaks JSX untuk membenamkan HTML untuk mencapai rendering pintar. 3) Kitaran Hayat Komponen Menguruskan Rendering HTML dan Kemas kini secara dinamik mengikut keadaan dan atribut. 4) Gunakan komponen untuk mengoptimumkan struktur HTML dan meningkatkan keupayaan. 5) Pengoptimuman prestasi termasuk mengelakkan penyampaian yang tidak perlu, menggunakan atribut utama, dan menjaga tanggungjawab tunggal komponen.

React and the Frontend: Membina Pengalaman InteraktifReact and the Frontend: Membina Pengalaman InteraktifApr 11, 2025 am 12:02 AM

React adalah alat pilihan untuk membina pengalaman front-end interaktif. 1) React memudahkan pembangunan UI melalui komponen dan DOM maya. 2) Komponen dibahagikan kepada komponen fungsi dan komponen kelas. Komponen fungsi adalah lebih mudah dan komponen kelas menyediakan lebih banyak kaedah kitaran hayat. 3) Prinsip kerja React bergantung kepada algoritma DOM dan perdamaian maya untuk meningkatkan prestasi. 4) Pengurusan negeri menggunakan useState atau ini. Kaedah kitaran hayat seperti ComponentDidMount digunakan untuk logik tertentu. 5) Penggunaan asas termasuk membuat komponen dan pengurusan negeri, dan penggunaan lanjutan melibatkan cangkuk tersuai dan pengoptimuman prestasi. 6) Kesalahan biasa termasuk kemas kini status yang tidak betul dan isu prestasi, kemahiran debugging termasuk menggunakan reactdevtools dan sangat baik

React and the Frontend Stack: Alat dan TeknologiReact and the Frontend Stack: Alat dan TeknologiApr 10, 2025 am 09:34 AM

React adalah perpustakaan JavaScript untuk membina antara muka pengguna, dengan komponen terasnya dan pengurusan negeri. 1) Memudahkan pembangunan UI melalui komponen dan pengurusan negeri. 2) Prinsip kerja termasuk perdamaian dan rendering, dan pengoptimuman dapat dilaksanakan melalui React.Memo dan Usememo. 3) Penggunaan asas adalah untuk membuat dan membuat komponen, dan penggunaan lanjutan termasuk menggunakan cangkuk dan konteksapi. 4) Kesalahan biasa seperti kemas kini status yang tidak betul, anda boleh menggunakan ReactDevTools untuk debug. 5) Pengoptimuman prestasi termasuk menggunakan react.memo, senarai virtualisasi dan codesplitting, dan menyimpan kod yang boleh dibaca dan dikekalkan adalah amalan terbaik.

Peranan React dalam HTML: Meningkatkan Pengalaman PenggunaPeranan React dalam HTML: Meningkatkan Pengalaman PenggunaApr 09, 2025 am 12:11 AM

React menggabungkan JSX dan HTML untuk meningkatkan pengalaman pengguna. 1) JSX membenamkan HTML untuk menjadikan pembangunan lebih intuitif. 2) Mekanisme DOM maya mengoptimumkan prestasi dan mengurangkan operasi DOM. 3) UI pengurusan berasaskan komponen untuk meningkatkan kebolehkerjaan. 4) Pengurusan negeri dan pemprosesan acara meningkatkan interaktiviti.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.