Nuxt SSR数据缓存优化

当前nuxt版本2.14.3 

axios数据缓存 

场景

纯数据列表展示,不对列表某些值进行手动修改,比如新闻列表等数据流

 1. 安装axios-extensions扩展 https://github.com/kuitos/axios-extensions  axios-extensions 3.1.3左右  该插件将提供axios数据缓存功能 
npm i axios-extensions -S //都安装在生产中
npm i LRUCache -S   //v:4.1.5左右



2. 在自定义的axios.js插件里面对axios进行扩展
import { cacheAdapterEnhancer } from 'axios-extensions'
import LRUCache from 'lru-cache' // 为了自定义缓存配置,如果不需要,可以不使用

export default function ({ $axios, redirect }) {
  // 请求中使用了useCache: true的话,会被缓存起来以便下次直接返回从而减少服务器压力
  let defaultAdapter = $axios.defaults.adapter
  let cacheCfg = new LRUCache({
    maxAge: 1000 * 10, //有效期10s
    max: 1000 // 最大缓存数量
  })
  $axios.defaults.adapter = cacheAdapterEnhancer(defaultAdapter, { enabledByDefault: false,     
  cacheFlag: 'useCache', defaultCache: cacheCfg })
}

// 3. 在api请求时添加useCache标志即可,如在某个页面中
export default {
  asyncData ({ params,$axios}) {
    let id = params.id
    return app.$axios.get(`/getDetail/?itemId=${id}`, {useCache: true}).then(res => {
      return (res && res.data) || {}
    })
  }
  //注意 只能使用$axios.get() //这种请求方式才能获得缓存功能
  //$axios({method:"get"})//无法获得缓存效果
}

注意点:

只有get请求可以被缓存。默认不启用缓存机制

如果需要对数据进行修改,需要对数据进行深克隆,否则,会影响到缓存数据

const res= awite $axios.get('xxxxxxx',{useCache:true}) 
//返回数据res={name:1,code:123}
delete res.code 
return {data:res} //第一次数据请求完成

//此时缓存中res为{name:1},delete影响了缓存中数据

深拷贝一份请求的结果
const result= JSON.parse(JSON.stringify(res)) //深拷贝一份,用这份数据delete不会影响缓存

 

组件缓存

  1. 不能依赖全局状态 比如依赖vuex的数据变更
  2. 不能对其他上下文组件有影响,
  3. 页面级添加serverCacheKey后,asyncData还是会执行,不过他的created等钩子函数将不再执行

场景

适用于单纯的v-for的数据展示列表 并且是根据某个属性id变更后才需要更新的列表

serverCacheKey: props => props.item.id + '::' + props.item.last_updated //属性id 加上时间戳


其他静态组件,永远不可能有更新的,比如页脚foouter,官网顶部header等静态内容,可以直接返回一个静态字符串,

 

 

 配置

npm i @nuxtjs/component-cache -S //下载组件缓存插件,官方社区提供

// 2. 在nuxt.config.js中配置模块

{
  modules: [
    ['@/nuxtjs/component-cache', { maxAge: 1000 * 60 }]
  ]
}


// 3. 按照vue ssr组件缓存的规则,在需要缓存的组件中,添加serverCacheKey,必须定义name,
// 在某vue组件中
<script>
export default {
  name: 'cache-com',//需要定义唯一的name字段
  props: {
    post: {
      type: String,
      required: true
    }
  },
  serverCacheKey: props => props.post,//由这个属性决定,如果变更,则组件将重新渲染,常量则会被静态化
}
</script>



serverCacheKey: () => Math.floor(Date.now() / (1000 * 60)),//一分钟刷新一次

组件缓存,只是缓存了dom结构,如created等钩子中的代码逻辑并不会被缓存,如果其中逻辑会影响上下边变更,是不会再执行的,此种组件也不适合缓存

 

 

 

### 如何在 Nuxt.js 中实现服务端数据缓存与读取 #### 使用 `nuxt-server-init` 进行全局状态初始化并设置缓存策略 为了提高性能,在服务器端渲染 (SSR) 的过程中可以利用 Vuex 来管理应用的状态,并通过自定义中间件或插件来处理缓存逻辑。对于全局性的初始加载,推荐使用 `nuxtServerInit` 方法。 当应用程序启动时会触发此函数执行一次,适合用来预填充 store 或者设定一些默认配置项。如果希望某些 API 请求的结果能够被持久化存储以便后续页面重用,则可以在该钩子内加入相应的缓存机制[^1]。 ```javascript // store/index.js export const actions = { async nuxtServerInit({ commit }, { app }) { let cachedData; try { // 尝试从本地文件系统或其他形式的外部缓存获取已有的响应副本 cachedData = await app.$axios.get('/api/cache'); if (!cachedData || !Object.keys(cachedData).length) throw new Error('No cache found'); console.log('Using server-side cache...'); commit('SET_GLOBAL_STATE', cachedData); } catch (_) { // 如果不存在有效缓存则发起实际请求并将结果保存下来供下次调用时作为缓存源 const freshData = await app.$axios.$get(process.env.API_URL); // 更新 Vuex Store 并创建新的缓存条目 commit('SET_GLOBAL_STATE', freshData); await app.$axios.post('/api/setCache', freshData); } }, }; ``` #### 利用 HTTP 响应头控制浏览器级别的资源缓存行为 除了上述基于 Vuex 的解决方案外,还可以借助于标准 Web 技术如 ETag、Last-Modified 等头部字段告知客户端哪些静态资产应该长期驻留内存之中而不必每次都重新下载;同时也可针对动态生成的内容指定较短的有效期以确保及时更新显示给用户的最新版本信息[^2]。 ```nginx location /static/ { expires max; # 设置最长过期时间 } location ~* \.(css|js)$ { add_header Cache-Control "public, no-transform"; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值