NuxtJS组件怎么请求接口

一、pages目录的页面请求接口

<script type="text/javascript">
export default{
	async asyncData(){
	    let res = await axios.get('https://xuexiluxian.cn/');
	}
}

二、components目录的组件请求接口

<script type="text/javascript">
export default{
	async fetch(){
            let res = await axios.get('https://xuexiluxian.cn/');
	}
}
</script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Nuxt 中,数据获取有两种方式:静态生成和服务端渲染。下面分别介绍这两种方式的正确的数据请求方法。 1. 静态生成 (generate) 在 nuxt.config.js 文件中配置 generate 属性,指定需要生成的静态页面和对应的数据来源。例如: ```js export default { generate: { routes: [ '/posts/1', '/posts/2', '/posts/3' ] } } ``` 如果需要根据接口动态生成静态页面,则可以在 generate 属性中使用 async 函数获取数据。例如: ```js export default { generate: { routes: async () => { const { data } = await axios.get('https://api.example.com/posts') return data.map(post => `/posts/${post.id}`) } } } ``` 2. 服务端渲染 (SSR) 在页面组件中,通过 asyncData 方法获取数据。例如: ```js export default { async asyncData({ params }) { const { data } = await axios.get(`https://api.example.com/posts/${params.id}`) return { post: data } } } ``` 需要注意的是,asyncData 方法只会在服务端执行,不会在客户端执行。在客户端执行的是 mounted 方法。因此,如果需要在客户端获取数据,可以在 mounted 方法中发起请求。例如: ```js export default { async asyncData({ params }) { const { data } = await axios.get(`https://api.example.com/posts/${params.id}`) return { post: data } }, mounted() { axios.get(`https://api.example.com/posts/${this.$route.params.id}`).then(({ data }) => { console.log(data) }) } } ``` 以上就是 Nuxt 中正确的数据请求方法。需要根据具体的业务场景选择不同的方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值