Rumah > hujung hadapan web > View.js > Kemahiran pembangunan Vue3+TS+Vite: Cara menggunakan TypeScript untuk meningkatkan kecekapan pembangunan

Kemahiran pembangunan Vue3+TS+Vite: Cara menggunakan TypeScript untuk meningkatkan kecekapan pembangunan

PHPz
Lepaskan: 2023-09-08 09:16:45
asal
638 orang telah melayarinya

Kemahiran pembangunan Vue3+TS+Vite: Cara menggunakan TypeScript untuk meningkatkan kecekapan pembangunan

Vue3+TS+Vite Petua Pembangunan: Cara menggunakan TypeScript untuk meningkatkan kecekapan pembangunan

Pengenalan:
Vue adalah popular Rangka kerja JavaScript, dan dengan keluaran Vue3, ia membawa banyak ciri dan penambahbaikan baharu. TypeScript ialah superset JavaScript yang ditaip kuat yang menyediakan sokongan alat dan keselamatan jenis yang lebih baik semasa pembangunan. Vite ialah alat binaan pantas yang menyediakan pelayan pembangunan yang berkuasa dan keupayaan kemas kini panas. Dalam artikel ini, kami akan menggunakan Vue3 digabungkan dengan TypeScript dan Vite untuk meneroka beberapa teknik yang boleh meningkatkan kecekapan pembangunan.

1 Konfigurasikan projek Vue3+TS+Vite
Untuk memulakan projek Vue3+TS+Vite, mula-mula kita perlu memasang Vue CLI:

npm install -g @vue/cli
Salin selepas log masuk

Kemudian dalam arahan Cipta projek Vue baharu dalam baris:

vue create my-project
Salin selepas log masuk

Pilih "Pilih ciri secara manual" untuk memilih ciri yang ingin anda tambahkan secara manual, dan kemudian pilih "TypeScript".

Selepas selesai, kita boleh menggunakan arahan berikut untuk memasuki direktori projek dan memulakan pelayan pembangunan:

cd my-project
npm run serve
Salin selepas log masuk

2. Taip inferens menggunakan TypeScript
Dalam Vue3, kita boleh Gunakan TypeScript untuk menyediakan penyemakan jenis dan inferens jenis yang lebih baik. Dengan mengisytiharkan jenis sifat seperti Props, data, pengiraan, dll., kami boleh memastikan bahawa kod itu lebih mantap semasa pembangunan.

Sebagai contoh, dalam komponen Vue, kita boleh mentakrifkan jenis Props dengan cara berikut:

import { defineComponent, PropType } from 'vue';

interface MyComponentProps {
  name: string;
  age: number;
}

export default defineComponent({
  props: {
    name: {
      type: String as PropType<MyComponentProps['name']>,
      required: true
    },
    age: {
      type: Number as PropType<MyComponentProps['age']>,
      default: 18
    }
  },
  setup(props) {
    // ...
  }
});
Salin selepas log masuk

Dalam contoh ini, kami menggunakan antara muka MyComponentProps< /code> untuk menentukan jenis Props dan gunakan <code>PropType dalam Props untuk menentukan jenisnya. Dengan cara ini kita boleh memastikan bahawa kita lulus dalam Props yang betul apabila menggunakan komponen dan mendapatkan petunjuk jenis yang betul apabila menggunakannya. MyComponentProps来定义Props的类型,并在Props中使用了PropType来指定类型。这样,我们可以确保在使用该组件时传入正确的Props,并在使用时获得正确的类型提示。

类似地,我们也可以在data、computed、methods等属性中使用TypeScript的类型推断,来增强代码的可读性和可维护性。

三、使用TypeScript的装饰器
TypeScript提供了一些装饰器,可以帮助我们在Vue3开发中更方便地使用一些高级特性。

  1. @Component装饰器
    在Vue2中,我们需要使用Vue.extend来创建一个Vue组件类。而在Vue3中,我们可以使用defineComponent函数来定义一个Vue组件。

为了使得代码更加清晰,我们可以使用@Component装饰器来代替defineComponent函数:

import { Component, Vue } from 'vue-class-component';

@Component
export default class MyComponent extends Vue {
  // ...
}
Salin selepas log masuk
  1. @Prop装饰器
    在Vue组件中,我们可以使用@Prop装饰器来声明一个Props属性,并指定其类型:
import { Component, Prop, Vue } from 'vue-class-component';

@Component
export default class MyComponent extends Vue {
  @Prop({ type: String, required: true })
  name!: string;
}
Salin selepas log masuk

这样,我们可以在组件中直接使用this.name来访问Props属性,并且可以得到正确的类型提示和检查。

四、使用Vue3的Composition API
Vue3引入的Composition API让我们能够更好地组织和重用代码逻辑。在使用TypeScript时,Composition API可以提供更好的类型推断和检查。

  1. 使用ref()reactive()函数
    在Vue3中,我们可以使用ref()函数来创建响应式变量,用于跟踪数据的变化。而使用reactive()函数可以将一个普通对象转化为响应式对象。
import { ref, reactive, onMounted } from 'vue';

export default defineComponent({
  setup() {
    const count = ref(0);
    const data = reactive({
      name: 'Alice',
      age: 18
    });

    onMounted(() => {
      count.value++; // ref需要通过value属性访问
    });

    return {
      count,
      data
    };
  }
});
Salin selepas log masuk

在这个例子中,我们使用了ref()函数来创建一个响应式的计数变量,并通过value属性来访问其值。同时,我们还使用了reactive()函数将data对象转化为响应式对象。

  1. 使用自定义的hooks
    在Composition API中,我们可以使用provideinject函数来进行数据传递。在使用TypeScript时,我们可以结合泛型来提供更好的类型检查。
import { InjectionKey, provide, inject } from 'vue';

interface MyContext {
  name: string;
  age: number;
}

const myKey: InjectionKey<MyContext> = Symbol();

export function provideMyContext(context: MyContext) {
  provide(myKey, context);
}

export function useMyContext(): MyContext {
  const context = inject(myKey);

  if (!context) {
    throw new Error('Cannot find MyContext');
  }

  return context;
}
Salin selepas log masuk

在这个例子中,我们使用了provideinject函数来提供和获取MyContext对象。通过泛型MyContext

Begitu juga, kami juga boleh menggunakan inferens jenis TypeScript dalam data, pengiraan, kaedah dan atribut lain untuk meningkatkan kebolehbacaan dan kebolehselenggaraan kod.


3 Menggunakan penghias TypeScript

TypeScript menyediakan beberapa penghias yang boleh membantu kami menggunakan beberapa ciri lanjutan dengan lebih mudah dalam pembangunan Vue3. #🎜🎜#
  1. @ComponentDecorator #🎜🎜#Dalam Vue2, kita perlu menggunakan Vue.extend untuk mencipta kelas komponen Vue. Dalam Vue3, kita boleh menggunakan fungsi defineComponent untuk mentakrifkan komponen Vue.
#🎜🎜#Untuk menjadikan kod lebih jelas, kita boleh menggunakan penghias @Component dan bukannya fungsi defineComponent: #🎜🎜 #rrreee
  • @Prop Decorator#🎜🎜#Dalam komponen Vue, kita boleh menggunakan penghias @Prop untuk mengisytiharkan Props atribut, Dan nyatakan jenisnya:
  • rrreee#🎜🎜#Dengan cara ini, kita boleh menggunakan this.name terus dalam komponen untuk mengakses atribut Props dan mendapatkan pembayang jenis yang betul dan periksa. #🎜🎜##🎜🎜#4 Gunakan API Komposisi Vue3#🎜🎜#API Komposisi yang diperkenalkan oleh Vue3 membolehkan kami mengatur dan menggunakan semula logik kod dengan lebih baik. API Komposisi menyediakan inferens jenis yang lebih baik dan semakan apabila menggunakan TypeScript. #🎜🎜#
    1. Gunakan fungsi ref() dan reactive() #🎜🎜#Dalam Vue3, kita boleh menggunakan ref() berfungsi untuk mencipta pembolehubah responsif untuk menjejaki perubahan data. Menggunakan fungsi reactive() boleh menukar objek biasa kepada objek responsif.
    rrreee#🎜🎜#Dalam contoh ini, kami menggunakan fungsi ref() untuk mencipta pembolehubah kiraan responsif dan menghantar harta value untuk diakses nilainya. Pada masa yang sama, kami juga menggunakan fungsi reactive() untuk menukar objek data kepada objek responsif. #🎜🎜#
    1. Gunakan cangkuk tersuai#🎜🎜#Dalam API Komposisi, kita boleh menggunakan fungsi provide dan inject untuk memindahkan data. Apabila menggunakan TypeScript, kami boleh menggabungkan generik untuk menyediakan pemeriksaan jenis yang lebih baik.
    rrreee#🎜🎜#Dalam contoh ini, kami menggunakan fungsi provide dan inject untuk menyediakan dan mendapatkan MyContext Objek. Melalui MyContext generik, kami boleh memastikan bahawa jenis yang diluluskan dan diterima adalah konsisten. #🎜🎜##🎜🎜#Kesimpulan: #🎜🎜#Artikel ini memperkenalkan beberapa teknik untuk menggunakan TypeScript untuk meningkatkan kecekapan pembangunan Vue3+Vite, termasuk inferens jenis, penghias, API Komposisi, dsb. Dengan menggunakan teknik ini dengan sewajarnya, kami boleh menjadikan kod lebih mantap, boleh dibaca dan meningkatkan kecekapan pembangunan. Saya harap petua ini boleh membantu kerja pembangunan anda dalam projek Vue3+TS+Vite. #🎜🎜#

    Atas ialah kandungan terperinci Kemahiran pembangunan Vue3+TS+Vite: Cara menggunakan TypeScript untuk meningkatkan kecekapan pembangunan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    sumber:php.cn
    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