电商系统基于nuxt的axios封装代码分享

背景

在电商系统中,一些场景需要使用nuxt服务器端渲染技术,如首页、商品详情页等等,目的是为了弥补vue单页的seo的不足。

基于nuxt项目的api请求需要处理服务器端请求、客户端请求分离,权限拦截,token统一传递等逻辑,本文以javashop电商系统中的代码为例,分享相关经验。

一 先引入

首先创建一个resquest.js,这里面存放的是axios配置以及拦截器,最后导出一个axios对象

import Vue from 'vue'
import axios from 'axios'
import https from 'https'
import { Loading } from 'element-ui'
import { api } from '@/ui-domain'
import Storage from '@/utils/storage'
import checkToken from '@/utils/checkToken'
const qs = require('qs')

二 创建axios实例,并且添加默认的配置

const service = axios.create({
  timeout: 8000,     // 请求超时时间
  baseURL: api.buyer, // 后端API,用于在服务器端进行请求
  httpsAgent: new https.Agent({
    rejectUnauthorized: false
  }),
  paramsSerializer: params => qs.stringify(params, { arrayFormat: 'repeat' })
})

三 创建request拦截器

配置全屏加载,引入ElementUI库

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kingapex1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值