我正在尝试使nuxt生成本地化的动态路由。我使用nuxt-i18n来翻译每条路线。
这是我的nuxt-i18n配置:
['nuxt-i18n', {
lazy: true,
locales: [
{
name: 'French',
code: 'fr',
iso: 'fr-ch',
file: 'fr.json'
},
{
name: 'German',
code: 'de',
iso: 'de-ch',
file: 'de.json'
},
{
name: 'Italian',
code: 'it',
iso: 'it-ch',
file: 'it.json'
},
],
langDir: 'lang/',
defaultLocale: 'fr',
parsePages: false,
pages: {
'advice/_uid': {
fr: '/conseil/:uid',
de: '/ratschlag/:uid',
it: '/consiglio/:uid',
},
}
}]
如文档中所述:
动态路由被generate命令(yarn generate)忽略。 Nuxt不知道这些路线是什么,因此无法生成 他们。
因此,我尝试改编their example,并使用无头CMS的Api重构了所有路由,但不幸的是,由于某种原因,nuxt并没有生成它们。我尝试使用文件结构(即/advice/_uid.vue
),而不是本地化的路由,希望nuxt-i18n会为我解决这个问题,但是从那边也没有运气。
这是我的nuxt.config.js:
import Prismic from 'prismic-javascript'
const prismicEndpoint = 'https://some-repository.cdn.prismic.io/api/v2'
const advices = () =>
Prismic.getApi(prismicEndpoint)
.then(api =>
api.query(Prismic.Predicates.at('document.type', 'advice'), {
pageSize: 100,
})
)
.then(res => {
return [
...res.results.map(advice => `/conseil/${advice.uid}`),
]
})
// Some more code...
export default {
// Some more code...
generate: {
fallback: '404.html',
advices
}
}
运行npm run generate
时没有错误,尽管它不会生成任何这些路由。
在我使用nuxt-i18n本地化路线之前,它曾经工作得很好
有什么方法可以使nuxt或nuxt-i18n生成局部动态路径吗?
感谢您的帮助!
答案 0 :(得分:0)
您确定您没有错字吗?
generate: {
fallback: '404.html',
advices
}
您的函数应该以{{1}}作为其键,因此应该是:
routes