🌮微卷不亏,4 分钟优化 Fetch 函数写法~

简介: 上一篇介绍了啥叫“微卷不亏”,今天继续简单微卷一些小知识点:本篇带来《如何优化 Fetch 函数写法》,轻松拿下~

image.png

本篇译自:javascript.plainenglish.io/how-to-make…

上一篇介绍了啥叫“微卷不亏”,今天继续简单微卷一些小知识点:本篇带来《如何优化 Fetch 函数写法》,轻松拿下~


冲!


常规 Fetch 是这样写的:


fetch('http://example.com/movies.json')
  .then(response => response.json())
  .then(data => console.log(data));


第一个 .then 里面是一个匿名函数,将返回转换为 json 格式;

这样写,不那么可读,且不够 DRY(Don't repeat yourself)~ 因为匿名函数并没有告诉你函数功能,并且每次 Fetch 都要转换数据为 json 的话,为什么不抽出一个可被复用的函数?


事实上,我们总是需要对从后端拿回的数据进行处理的,所以将处理过程进行封装也是有必要的~


function getResponse(response)
{ return response.json() }
fetch('http://example.com/movies.json')
  .then(getResponse)
  .then(data => console.log(data));


以,同样的道理,将第二个 .then 内部的匿名函数进行封装:


function processJSON(json)
{
  for(let i = 0; i < json.length; i++)
  {
    console.log(json[i])
  }
}
fetch('http://example.com/movies.json')
  .then(getResponse)
  .then(processJSON);


Wow! 现在 fetch 函数看起来清晰多了!fetch => 处理响应 => 处理 JSON 数据;语义化的代码,所见即所是!


PS:其实,这个思想和函数式编程也是一致的,减少使用匿名函数,将处理过程用函数封装,封装函数的函数名都是有具体含义的,让它们来处理数据流,这才是正真可读的代码~


上述代码,处理还能更进一步:

const moviesPath = 'http://example.com/movies.json'
fetch(moviesPath)
  .then(getResponse)
  .then(processJSON); 


这就是 Fetch 函数清爽干净的样子!


再举个栗子🌰


  • POST 写法


// 优化前

fetch('https://example.com/profile', {
  method: 'POST', // or 'PUT'
  headers: {
    'Content-Type': 'application/json',
  },
  body: JSON.stringify(data),
})
.then(response => response.json())


// 优化后

function writeServer(action, data={})
{ return { method: action, headers: { 'Content-Type': 'application/json' }, body: JSON.stringify(data) } }
fetch(moviesPath, writeServer("POST", newMovie))
  .then(getResponse)
  .then(processJSON);
复制代码


这就是 DRY!这就是声明式代码!这就是更可读的代码!

image.png


看到这里,我们也知道了,这种优化思路(封装、声明式、数据流)不仅仅限于 Fetch 函数中,其它数据处理的过程都可以应用~ 从细节着手!

OK,以上便是本篇分享;撰文不易,点赞鼓励👍👍👍


相关文章
|
前端开发 JavaScript API
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(五)
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(五)
|
7月前
|
安全 算法 编译器
C++中=delete的巧妙用法
C++中=delete的巧妙用法
191 0
|
7月前
|
SQL
Greenplum【SQL 03】实现树结构+自定义函数+避免函数重复调用+ function cannot execute on a QE slice 问题处理(优化过程全记录)
Greenplum【SQL 03】实现树结构+自定义函数+避免函数重复调用+ function cannot execute on a QE slice 问题处理(优化过程全记录)
161 0
|
编译器 C语言
【C语言】 函数(下):函数的嵌套调用 -- 链式访问 -- 声明 -- 定义 -- 递归 -- 练习1
【C语言】 函数(下):函数的嵌套调用 -- 链式访问 -- 声明 -- 定义 -- 递归 -- 练习1
|
前端开发 网络架构
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(一)
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map
|
前端开发 JavaScript 网络架构
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(三)
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(三)
|
前端开发 网络架构
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(二)
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(二)
|
前端开发 API 网络架构
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(六)
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(六)
|
前端开发 网络架构
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(四)
ES6-ES11-第一部分-let、const、解构赋值、模板字符串、简化对象写法、箭头函数、函数参数默认值、rest 参数、扩展运算符、Symbol、迭代器、生成器、Promise、Set、Map(四)
|
小程序 前端开发
小程序里使用es7的async await语法
小程序里使用es7的async await语法
124 0