Ajax:原生ajax、使用FormData的细节问题,数据的载体

news2024/10/18 12:50:34

人生海海,山山而川,不过尔尔;空空而来,苦苦而过,了了而去

文章目录

          • 原生ajax
          • 使用FormData的细节问题
          • 数据的载体

原生ajax
  • 执行顺序
    1. 创建xhr对象 var xhr = new XMLHttpRequest()
    2. 调用xhr.open('请求方式', url)函数,设置请求方式和接口地址
    3. 调用xhr.send函数,用于发送请求
    4. 监听xhr.onreadystatechange事件,获取接口返回的结果
  • 关于readyState属性
    • readyState的值有5个,分别是0-4,该属性表示ajax请求过程中的5个不同的状态
    • 我们关心的是xhr.readyState===4的时候,因为这个时候浏览器端可以准确的完整的接收到服务器返回的数据
  • 带参数的GET请求
    • xhr.open('GET', 'http://www.liulongbin.top:3006/api/getbooks?id=3') 多个参数用&符号隔开
  • POST请求
    • 参数位置不同,POST请求时提交的数据要当做 xhr.send() 的参数
    • open和send方法之间,需要指定header头
  • 编码中文
    • url中不要出现中文,如查询字符串中有英文,我们最好使用js函数encodeURL()对中文进行编码处理
  • XMLHttpRequest Level 2新特性
    • xhr.onload:在完成ajax请求完毕的时候会触发
    • xhr.reponse:可以接收任何类型的结果
  • xhr配合ForData使用
    1. 获取表单数据
      • 找到表单的dom对象
      • 实例化FormData,参数是前面得到的dom对象
    2. ajax提交到接口
      • 指定POST方式提交到指定的接口
      • 不要写setquestHeader
      • 数据当做send的参数直接使用即可
使用FormData的细节问题
  • 注意事项
    • 表单各项(input/select/textarea)必须有name属性,因为FormData就是根据name属性来收集数据的
    • 找form表单的时候一定要用dom对象
    • 发送ajax请求的时候必须使用POST方式
    • 接口必须使用指定的接口
  • API
    • get('username'):判断FormData对象中的username的值
    • has('username'):判断FormData对象中是否有username
    • append('time',Data now()):向FormData对象中追加一条数据
数据的载体
  • JSON (JavaScript Object Notation )
    • 作用:json是一种超轻量级的数据交换格式 (实际上是JavaScript的子集)
    • 注意事项
      • 属性名必须要用双引号包裹
      • 字符串类型的值必须用双引号包裹
      • json中不能写注释
      • json的最外层必须是对象或数组格式
      • 不能使用undefined或函数作为json的值
    • 序列化:即把js对象转成json格式的字符串的过程,使用方法为 JSON.stringify()
      var xiaoming = {
        name: '小明',
        age: 12,
       	gender: true,
        height: 165,
        grade: null,
        'middle-school': 'Middle School',
        skills: ['Javascript', 'Java', 'Python', 'Lisp']
      }
      var res = JSON.stringify(xiaoming)
      console.log(res)
      // 运行结果: {"name":"小明","age":12,"gender":true,"height":1.65,"grade":null,"middle-school":"Middle School","skills":["Javascript","Java","Python","Lisp"]}
      // 如果要输出好看一些的话, 可以加上参数,按缩进输出 JSON.stringify(xiaoming, null, ' ')
      // 运行结果:{
                    "name": "小明",
                    "age": 14,
                    "gender": true,
                    "height": 1.65,
                    "grade": null,
                    "middle-school": "Middle School",
                    "skills": [
                      "JavaScript",
                      "Java",
                      "Python",
                      "Lisp"
                    ]
                  }
      // 第二个参数用于控制如何筛选对象的赋值,如果只想输出指定的属性,可以传入Array:JSON.stringify(xiaoming, ['name', 'skills'], ' ')
      // 运行结果:  {
                    "name": "小明",
                    "skills": [
                      "JavaScript",
                      "Java",
                      "Python",
                      "Lisp"
                    ]
                  }
      // 其中第三个参数
      	1.如果省略的话显示出来的值就没有分隔符,直接输出来
      	2.如果是一个数字的话定义的是缩进几个字符,如果大于10,则默认为10,因为最大值为10
      	3.如果是一些转义字符,比如'\t',表示回车,那么它每行一个回车
      	4.如果仅仅是字符串,就在每行输出值的时候就把这些字符串附加上去,最大长度也是10个字符
      
  • 反序列化:即把json格式的字符串转成js对象的过程,使用方法为 JSON.parse()
    var res = JSON.parse('[1,2,3,true]')
    console.log(res) // [1,2,3,true]
    var res = JSON.parse('{"name": "小明", "age": 14}')
    console.log(res) // {name: '小明', age:14}
    var res = JSON.parse('true')
    console.log(res) // true
    var res = JSON.parse('123.45')
    console.log(res) // 123.45
    // 还可以接收一个函数,用来转换解析出的属性
    var obj = JSON.parse('{"name":"小明","age":14}', function (key, value) {
      if (key === 'name') {
        return value + '同学'
      }
      return value
    })
    console.log(JSON.stringify(obj)) // {"name":"小明同学","age":14}
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2217783.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

HarmonyOS 开发知识总结

1. HarmonyOS 开发知识总结 1.1. resources->base->media中不可以新建文件夹? 项目图片路径resources->base->media中不可以新建文件夹,图片全平级放里面,查找图片不方便,有没有什么其他的办法解决这个难点&#xff…

软件测试学习笔记丨Pycharm运行与调试

本文转自测试人社区,原文链接:https://ceshiren.com/t/topic/23454 Pycharm作为集成开发环境,除了可以编写脚本,还可以运行和调试自己的代码,下面就为大家介绍一下pycharm运行和调试代码的功能如何使用。 代码运行 编…

银行卡风险画像在风险防控中的作用

现在,网络诈骗涉及到银行卡转账的案例不在少数,在这种背景下,如何有效识别、预防和控制银行卡风险,成为银行业及监管机构面临的问题之一。 银行卡风险画像,简而言之,是基于持卡人交易行为、个人信息、信用记…

高级算法设计与分析 学习笔记14 FFT

​ 本章我们研究多项式乘法。 我们直接乘,时间复杂度是n^2。使用FFT则可以变成nlgn ​编辑 可以看到两个n的多项式,我们直接乘,每种组合都要试一遍,就会要是n^2遍 ​编辑 那么要怎么加速呢? ​编辑 首先多项式可…

用户界面设计:视觉美学与交互逻辑的融合

1、什么是用户界面 用户界面(UI)是人与机器之间沟通的桥梁,同时也是用户体验(UX)的重要组成部分。用户界面设计包括两个核心要素:视觉设计(即产品的外观和感觉)和交互设计&#xff…

鸿蒙网络编程系列21-使用HttpRequest上传任意文件到服务端示例

1. 前述文件上传功能简介 在前述文章鸿蒙网络编程系列11-使用HttpRequest上传文件到服务端示例中,为简化起见,只描述了如何上传文本类型的文件到服务端,对文件的大小也有一定的限制,只能作为鸿蒙API演示使用,在实际开…

postgresql执行计划解读案例

简介 SQL优化中读懂执行计划尤其重要,以下举例说明在执行计划中常见的参数其所代表的含义。 创建测试数据 -- 创建测试表 drop table if exists customers ; drop table if exists orders ; drop table if exists order_items ; drop table if exists products ;…

加速功能安全AI 智能化:HIRAIN FuSa AI Agent发布

随着汽车电子电气(E/E)系统复杂性的增加,以及自动驾驶技术的迅猛发展,功能安全研发面临着日益严峻的挑战,研发成本也随之上升。面对这一挑战,经纬恒润凭借在功能安全领域的深厚积累,利用前沿的人…

页面局部使用vue等框架其它部分用JQuery进行交互

这个需求是原有django在网页需要定制一个人员签到信息。状态有三种,在岗,下班。好吧两种。但是你想 1,1.这是两次、共四个可能,00, 10,01,11.其中00是在家。10是在岗。01是。不签到只签退&#…

vue3使用element-plus手动更改url后is-active和菜单的focus颜色不同步问题

在实习,给了个需求做个新的ui界面,遇到了一个非常烦人的问题 如下,手动修改url时,is-active和focus颜色不同步 虽然可以直接让el-menu-item:focus为白色能解决这个问题,但是我就是想要有颜色哈哈哈,有些执…

一买一卖利润赛苹果,二手平台把阴阳检测玩明白了……

小柴最近看到这样一个案例,一网友在社交媒体上哭诉称,自己在某二手平台上看中了一支二手Apple pencil二代触控笔。 平台给出的检测报告显示,该产品是外观完好、功能完好接近全新的S等级产品,这位网友像捡到了宝一样,立…

不入耳开放式耳机哪个品牌好?这些品牌骨灰级开放式耳机推荐

开放式耳机以其独特的设计,不仅避免了长时间佩戴对耳朵造成的压迫感,还能让用户在享受音乐的同时保持对外界的感知,极大提升了使用安全性和舒适度。特别是对于那些长时间佩戴耳机的用户或是户外运动爱好者来说,开放式耳机无疑是一…

网页复制粘贴助手,Chrome网页复制插件(谷歌浏览器复制插件)

一款解决网页限制复制问题的插件,当你遇到限制复制粘贴和右键的网页是不是很头痛?安装这个插件后,点下插件按钮就能解决了 碰到这种情况 也是非常头疼 chrome拓展-chrome插件-强制复制 当我们浏览网页的时候,看到感兴趣的内容就…

Github 优质项目推荐(第七期)

文章目录 Github优质项目推荐 - 第七期一、【LangGPT】,5.7k stars - 让每个人都成为提示专家二、【awesome-selfhosted】,198k stars - 免费软件网络服务和 Web 应用程序列表三、【public-apis】,315k stars - 免费 API四、【JeecgBoot】&am…

校验台账生成网络事业调查表的方法

校验台账生成网络事业调查表的方法 一、打开教育事业统计调查表学校(机构)信息管理标准化台账“采集信息核查辅助工具二、导入本校台账并校验三、调查表统计导出四、完 一、打开教育事业统计调查表学校(机构)信息管理标准化台账“…

[已解决] pycharm添加本地conda虚拟环境 + 配置解释器 - pycharm找不到conda可执行文件

目录 问题: 方法: 补充:创建conda虚拟环境 参考文档:pycharm找不到conda可执行文件怎么办?-CSDN 问题: 1.显示:未为项目配置 Python 解释器 2.想在pycharm中使用本地创建的虚拟环境 方法&a…

请问医药销售智能仓系统包含哪些功能流程?

第一部分:医药销售智能仓系统功能清单 一、入库管理 货物信息录入 功能描述:支持手动输入或扫描药品包装上的条形码、二维码等,录入药品名称、规格、批次、有效期、生产厂家等信息。流程:操作人员使用扫描设备读取药品信息,系统自…

python实现屏幕录制,录音录制工具

python实现屏幕录制,录音录制工具 一,介绍 Python 实现的屏幕录制和录音录制工具是一个便捷的应用程序,旨在帮助用户同时捕捉计算机屏幕上的活动以及与之相关的音频输出。这个工具尤其针对教育工作者、内容创作者、技术支持人员以及任何需要…

uniapp使用html2canvas时,页面内的image元素模糊

不废话很简单只需要将image改成img就行 改之前 改之后 原因可能是因为uniapp里面的image标签做了某种处理

信息搜集 --子域名

1.证书查询 通过ssl证书指纹在crt.sh |证书搜索网站搜索 这些就是证书一样的 2.fofa等空间测绘平台查询 3.dns查询 https://dnsdumpster.com/ 4.威胁情报中心 360 微步等等 5.枚举 暴力破解 工具推荐:oneforall GitHub - shmilylty/OneForAll: OneForAll是一款…