如今前后端交互多用json进行参数传递,也就是application/json
但是有些特殊场景会用到其他content-type,如文件上传,这时候可以通过设置请求头的content-type来达到和原生form表单一样的效果
application/x-www-form-urlencoded: 窗体数据被编码为名称/值对。这是标准的编码格式。

multipart/form-data: 窗体数据被编码为一条消息,页上的每个控件对应消息中的一个部分

application/x-www-form-urlencoded

form表单默认的格式,用于上传普通字段,会被解析成

	 const params = new URLSearchParams();
      params.append('domains', domains.split(','));
      params.append('icpYes', icpYes);

multipart/form-data

form表单设置enctype="multipart/form-data"时的格式,传文件时用到

      const formData = new FormData();
      const file=feil.file
      const mailSys=values.mailSys
      formData.append('file',file);
      formData.append('mailSys',mailSys);

需要注意的是formData对象进行append之后是console不出来的需要调用formData.get(),getAll()等方法

有想换工作的同学可以找我内推哦不低于15k(前端,java,测试)

更多推荐

原生form表单的Content-Type