加入收藏 | 设为首页 | 会员中心 | 我要投稿 河北网 (https://www.hebeiwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

前端API请求缓存方案

发布时间:2019-04-24 14:02:34 所属栏目:建站 来源:jump--jump
导读:在开拓 web 应用措施时,机能都是必不行少的话题。对付webpack打包的单页面应用措施而言,我们可以回收许多方法来对机能举办优化,例如说 tree-shaking、模块懒加载、操作 extrens 收集cdn 加快这些通例的优化。乃至在vue-cli 项目中我们可以行使 --modern

此时数据类以及操纵类 都已经界说好,我们可以在api层这样界说

  1. // 天生key值错误  
  2. const generateKeyError = new Error("Can't generate key from name and argument")  
  3. // 天生key值  
  4. function generateKey(name, argument) {  
  5. // 从arguments 中取得数据然后变为数组  
  6. const params = Array.from(argument).join(',')  
  7. try{  
  8. // 返回 字符串,函数名 + 函数参数  
  9. return `${name}:${params}`  
  10. }catch(_) {  
  11. // 返回天生key错误  
  12. return generateKeyError  
  13. }  
  14. }  
  15. async getWare(params1, params2) {  
  16. // 天生key  
  17. const key = generateKey('getWare', [params1, params2])  
  18. // 得到数据  
  19. let data = ExpriesCache.get(key)  
  20. if (!data) {  
  21. const res = await request('/getWares', {params1, params2})  
  22. // 行使 10s 缓存,10s之后再次get就会 获取null 而从处事端继承哀求  
  23. ExpriesCache.set(key, res, 10)  
  24. }  
  25. return data  
  26. }  

该方案行使了 逾期时刻 和 api 参数差异而举办 缓存的方法。已经可以满意绝大部门的营业场景。

挪用方法

  1. getWares(1,2).then( ... )  
  2. // 第二次挪用 取得先前的promise  
  3. getWares(1,2).then( ... )  
  4. // 差异的参数,不取先前promise  
  5. getWares(1,3).then( ... )  

方案五 基于修饰器的方案四

和方案四是的解法同等的,可是是基于修饰器来做。代码如下:

  1. // 天生key值错误  
  2. const generateKeyError = new Error("Can't generate key from name and argument")  
  3. // 天生key值  
  4. function generateKey(name, argument) {  
  5. // 从arguments 中取得数据然后变为数组  
  6. const params = Array.from(argument).join(',')  
  7. try{  
  8. // 返回 字符串  
  9. return `${name}:${params}`  
  10. }catch(_) {  
  11. return generateKeyError  
  12. }  
  13. }  
  14. function decorate(handleDescription, entryArgs) {  
  15. // 判定 当前 最后数据是否是descriptor,假如是descriptor,直接 行使  
  16. // 譬喻 log 这样的修饰器  
  17. if (isDescriptor(entryArgs[entryArgs.length - 1])) {  
  18. return handleDescription(...entryArgs, [])  
  19. } else {  
  20. // 假如不是  
  21. // 譬喻 add(1) plus(20) 这样的修饰器  
  22. return function() {  
  23. return handleDescription(...Array.protptype.slice.call(arguments), entryArgs)  
  24. }  
  25. }  
  26. }  
  27. function handleApiCache(target, name, descriptor, ...config) {  
  28. // 拿到函数体并生涯  
  29. const fn = descriptor.value  
  30. // 修改函数体  
  31. descriptor.value = function () {  
  32. const key = generateKey(name, arguments)  
  33. // key无法天生,直接哀求 处事端数据  
  34. if (key === generateKeyError) {  
  35. // 操作适才生涯的函数体举办哀求  
  36. return fn.apply(null, arguments)  
  37. }  
  38. let promise = ExpriesCache.get(key)  
  39. if (!promise) {  
  40. // 设定promise  
  41. promise = fn.apply(null, arguments).catch(error => {  
  42. // 在哀求返来后,假如呈现题目,把promise从cache中删除  
  43. ExpriesCache.delete(key)  
  44. // 返回错误  
  45. return Promise.reject(error)  
  46. })  
  47. // 行使 10s 缓存,10s之后再次get就会 获取null 而从处事端继承哀求  
  48. ExpriesCache.set(key, promise, config[0])  
  49. }  
  50. return promise  
  51. }  
  52. return descriptor;  
  53. }  
  54. // 拟定 修饰器  
  55. function ApiCache(...args) {  
  56. return decorate(handleApiCache, args)  
  57. }  

(编辑:河北网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读