Saya ingin membuat pengalih bahasa di aplikasi nuxt saya dengan plugin nuxt-i18n. Catatan penting adalah, saya menggunakan TypeScript alih-alih JavaScript.

Seperti dalam dokumentasi (https://i18n.nuxtjs.org/lang-switcher) saya mengimplementasikan kode berikut ke dalam komponen Navbar saya:

TheNavbar.vue

<template>
  <nav class="navbar">
    <div class="container">
      <div>
        <NuxtLink
          v-for="locale in availableLocales"
          :key="locale.code"
          :to="switchLocalePath(locale.code)">{{ locale.name }}
        </NuxtLink>
      </div>
    </div>
  </nav>
</template>

<script lang="ts">
import Vue from 'vue';

export default Vue.extend({
  name: "TheNavbar",
  computed: {
    availableLocales() {
      return this.$i18n.locales.filter(i => i.code !== this.$i18n.locale);
    }
  }
})

Di aplikasi saya, solusi ini berfungsi. Tetapi konsol mencetak dua kesalahan berikut:

 ERROR  ERROR in src/components/shared/TheNavbar.vue:25:14                                                                                                                                                       18:49:05
TS2532: Object is possibly 'undefined'.
    23 |   computed: {
    24 |     async availableLocales() {
  > 25 |       return this.$i18n.locales.filter(i => i?.code !== this.$i18n.locale);
       |              ^^^^^^^^^^^^^^^^^^
    26 |     }
    27 |   }
    28 | })


ERROR in src/components/shared/TheNavbar.vue:25:48
TS2339: Property 'code' does not exist on type 'string | LocaleObject'.
  Property 'code' does not exist on type 'string'.
    23 |   computed: {
    24 |     async availableLocales() {
  > 25 |       return this.$i18n.locales.filter(i => i?.code !== this.$i18n.locale);
       |                                                ^^^^
    26 |     }
    27 |   }
    28 | })

Konfigurasi i18n saya di nuxt.config.js:

  i18n: {
    locales: [
      {
        code: 'de',
        name: 'Deutsch',
      },
      {
        code: 'en',
        name: 'English'
      }
    ],
    defaultLocale: 'de',
    vueI18n: {
      fallbackLocale: 'de',
      messages: {
        de: {
          welcome: 'Willkommen'
        },
        en: {
          welcome: 'Welcome'
        }
      }
    }
  },
0
Cenasa 29 November 2020, 20:56

2 jawaban

Jawaban Terbaik

Coba ini:

<NuxtLink
   v-if="availableLocales"
   v-for="locale in availableLocales"
   :key="locale.code"
   :to="switchLocalePath(locale.code)">{{ locale.name }}
</NuxtLink>
1
Mirco Cattabriga 29 November 2020, 18:27

Karena saya baru mulai mendalami TS, saya mengalami masalah serupa: Saya mencoba mengakses this.$store.* di dalam computed. Saya pikir masalah dasarnya adalah sama.

"Vuex tidak menyediakan tipe yang berguna untuk mengakses toko dari aplikasi Anda. this.$store tetap tidak diketik di aplikasi Nuxt." - dokumen Nuxt

Saya kira i18n juga tidak.

Saran yang diberikan oleh dokumen adalah membuat jenis Anda sendiri atau menemukan plugin pengetikan.

// -- components/MyComponent.vue

<script lang="ts">

import { Component, Vue } from 'nuxt-property-decorator'
import { getters, RootState } from '~/store'

@Component
export default class MyComponent extends Vue {
    get myThings() {
        return (this.$store.state as RootState).things
    }

    mounted() {
        const name = this.$store.getters['name'] as ReturnType<typeof getters.name>
    }
}
0
liminor 4 Desember 2020, 21:28