Rumah > hujung hadapan web > View.js > Cara menggunakan API Komposisi tema lanjutan Vue3

Cara menggunakan API Komposisi tema lanjutan Vue3

王林
Lepaskan: 2023-05-21 12:58:12
ke hadapan
1099 orang telah melayarinya

Apakah itu API Komposisi

API Komposisi ialah gaya API baharu yang diperkenalkan dalam Vue3, bertujuan untuk meningkatkan kebolehbacaan, kebolehselenggaraan dan kebolehgunaan semula kod. API Komposisi berbeza daripada API Pilihan dalam Vue2 Ia menggunakan kaedah pengaturcaraan berasaskan fungsi untuk menguraikan logik dalam komponen kepada unit fungsi boleh gubah yang lebih kecil untuk mencapai organisasi kod yang lebih fleksibel dan cekap.

Mengapa Vue3 mengesyorkan menggunakan API Komposisi

Sebab utama mengapa Vue3 mengesyorkan menggunakan API Komposisi adalah untuk menyusun dan menggunakan semula logik komponen dengan lebih baik.

Dalam Vue2, kami biasanya menggunakan API Pilihan, di mana kami mentakrifkan gelagat komponen dengan mentakrifkan pilihan yang berbeza seperti data, kaedah, pengiraan, dsb. Terdapat beberapa kelemahan pada pendekatan ini, seperti:

  • Komponen besar menjadi sukar untuk diselenggara kerana kod yang berkaitan bertaburan merentasi pilihan yang berbeza.

  • Komponen besar mungkin mempunyai logik pendua kerana kod itu sukar untuk digunakan semula.

  • Ia boleh menjadi sukar untuk menjejak atribut data mana yang diubah suai dan bila.

Mari kita ambil contoh mudah di bawah Kod berikut mentakrifkan logik untuk mendapatkan data:

import { reactive, onMounted } from 'vue'
import axios from 'axios'
export function useData(url) {
  const data = reactive({
    loading: false,
    error: null,
    items: []
  })
  const fetchData = async () => {
    data.loading = true
    try {
      const response = await axios.get(url)
      data.items = response.data
    } catch (error) {
      data.error = error.message
    }
    data.loading = false
  }
  onMounted(() => {
    fetchData()
  })
  return {
    data,
    fetchData
  }
}
Salin selepas log masuk

Logik ini merangkumi kaedah pemerolehan data, pemprosesan status pemuatan dan Logik untuk ralat. mesej dll. Kita boleh menggunakan logik ini dalam berbilang komponen untuk mengelakkan pertindihan kod.

Sebagai contoh, gunakan logik ini dalam komponen:

import { useData } from './useData'
export default {
  setup() {
    const { data } = useData('https://api.example.com/data')
    return {
      data
    }
  }
}
Salin selepas log masuk

Sudah tentu, Vue2 juga boleh mencapai fungsi di atas melalui mixin, tetapi kebolehbacaan dan kebolehselenggaraan tidak sebaik Komposisi API:

const dataMixin = {
  data() {
    return {
      loading: false,
      error: null,
      items: []
    }
  },
  methods: {
    fetchData() {
      this.loading = true
      axios.get(this.url)
        .then(response => {
          this.items = response.data
        })
        .catch(error => {
          this.error = error.message
        })
        .finally(() => {
          this.loading = false
        })
    }
  },
  mounted() {
    this.fetchData()
  }
}
Salin selepas log masuk

dan kemudian gunakannya dalam komponen:

export default {
  mixins: [dataMixin],
  data() {
    return {
      url: 'https://api.example.com/data'
    }
  }
}
Salin selepas log masuk

Anda dapat melihat bahawa menggunakan mixin boleh mencampurkan logik awam ke dalam komponen, tetapi terdapat beberapa masalah dalam pencampuran, seperti konflik penamaan, urutan panggilan mata kait kitaran hayat dan isu lain.

Atas ialah kandungan terperinci Cara menggunakan API Komposisi tema lanjutan Vue3. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan