Blogger Information
Blog 19
fans 0
comment 1
visits 14185
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
json/Ajax异步请求
Original
652 people have browsed it

数组常用方法

-他们时仅在一端进行增删的数组

  • 栈方法:后进先出
  • 队:先进先出
  • push 写进 pop()在数组的尾部进行增删
  • unshift() shift()在数组的头部进行增删
  • join(): 指定分割符返回字符串 与split()相反
  • concat() 数组合并
  • slice() 返回数组中的部分成员 创建数组副本
  • splice(开始索引,删除的数量,插入的数据。。) 数组的增删改,它的本职工作时删除元素
  • 排序 sort()
  • map()
  • 过滤 filter()
  • reduce(callback(perv,curr),0)
  1. <script>
  2. //使用 push() pop()
  3. let arr = []
  4. console.log(arr.push(1,2,3))
  5. console.log(arr);
  6. console.log(arr.pop())
  7. //使用unshift() shift()
  8. console.log(arr)
  9. console.log(arr.unshift(1,2,3))
  10. console.log(arr)
  11. console.log(arr.shift())
  12. console.log(arr.shift())
  13. console.log(arr.shift())
  14. // push()+shift() 模拟队列:尾部进入,头部出去
  15. console.log(arr)
  16. console.log(arr.push(1,2,3))
  17. console.log(arr)
  18. console.log(arr.shift())
  19. console.log(arr.shift())
  20. console.log(arr.shift())
  21. // pop()+unshift() 模拟队列,头部进入,尾部出去
  22. console.log(arr)
  23. console.log(arr,unshift(1,2,3))
  24. console.log(arr)
  25. console.log(arr.pop())
  26. console.log(arr.pop())
  27. console.log(arr.pop())
  28. //join()
  29. arr = ['电脑','手机','相册']
  30. let res = arr.join('---')
  31. console.log(res)
  32. let str = 'hello' console.log(str[0],str[1].str[2].str[3].str[4])
  33. //concat()数组合并
  34. console,log('hello'.concat(php.cn))
  35. console.log([1,2,3].concat([4,5],[6,7]))
  36. // slice() 返回数组中的部分成员
  37. arr = [1,2,3,4,5]
  38. res = arr.slice(0)
  39. console.log(res)
  40. res[1] = 888
  41. console.log(arr)
  42. //取最后两个
  43. console.log(arr.slice(3))
  44. console.log(arr.slice(-2))
  45. //splice() 数组的增删改吗,它的本职工作时删除元素
  46. arr = [1,2,3,4,5]
  47. res = arr.splice(2)
  48. //返回被删除的元素
  49. console.log(res)
  50. // 当前数组中仅有1,2
  51. console.log(arr)
  52. //更新操作
  53. arr = [1,2,3,4,5]
  54. res = arr.splice(1,2,88,99)
  55. console.log(res)
  56. console.log(arr)
  57. // 添加
  58. arr = [1,2,3,4,5]
  59. //将第二个人参数设置为0,这样就不会有元素被删除
  60. res = arr.splice(1,0,...[88,99])
  61. console.log(res)
  62. console.log(arr)
  63. // 排序
  64. arr = ['p','b','c']
  65. console.log(arr)
  66. // 默认按字母表顺序
  67. arr.sort()
  68. console.log(arr)
  69. //arr.sort()
  70. arr.sort((a,b)=>a-b)
  71. console.log(arr)
  72. // 遍历 map
  73. console.log(arr)
  74. //没有返回值
  75. arr.forEach(item=>console.log(item))
  76. //map 对数组每个成员都调用回调进行处理并返回这个数值
  77. res = arr.map(item=>item)
  78. console.log(res)
  79. //过滤
  80. arr = [1,2,3,4,5]
  81. res = arr.filter(item => item % 2)
  82. console.log(res)
  83. //归并 reduce()
  84. reduce(callback(prev,curr))
  85. arr = [1,2,3,4,5]
  86. res = arr.reduce((prev,curr)=>{
  87. //console.log(prev,curr)
  88. return prev + curr
  89. })
  90. </script>

json

1.JSON 是什么

  • JSON:独立与任何编程语言,几乎所有编程语言都提供访问JSON 数据 API 接口
  • JSON 是一种语法,用来序列化其他语言创建的数据类型
  • JSON 仅支持6种数据类型,对象,数组,数值,字符串,布尔值,null
  • JSON 只是借用了 JS 中的一些数据表示语法,与JS并无关系

2. JSON 数据类型

序号 类型 描述
1 简单值 数值,字符串,布尔,null
2 复合值 对象,数组
  1. 注意:不支持undefined (因为除JS外,其他语言中没有这个东西)

3. JS 解析JSON 的 API

序号 方法 描述
1 JSON.stringify() 将JS对象,序列化JSON字符串
2 JSON.parse() 将JSON 字符串,解析为JSON 对象
  1. <script>
  2. //JSON : stringify(data,replacer,space):将js数据转为JSON
  3. console.log(JSON.stringify(3.13),typeof JSON.stringify(3.14))
  4. //字符串 必须加引号
  5. console.log(JSON.stringify("php.cn"),typeof JSON.stringify("php.cn"))
  6. //true 不用加引号
  7. console.log(JSON.stringify(true),typeof JSON.stringify(true))
  8. //null 不用加引号
  9. console.log(JSON.stringify(null),typeof JSON.stringify(null))
  10. // object
  11. //JSON 对象的属性必须加双引号,字符串也必须加引号
  12. console.log(JSON.stringify({x:'a',y:'b'}))
  13. //arrat
  14. console.log(JSON.stringify([1,2,3]),typeof JSON.stringify([1,2,3]))
  15. //JSON 其实不是数据类型,只是一个具有特殊格式的字符串而已
  16. /*会对json 格式字符串的特殊操作,主要通过后面二个参数
  17. 第二个参数支持 数组 和函数*/
  18. //数组
  19. console.log(JSON.stringify({a:1,b:2,c:3}))
  20. console.log(JSON.stringify({a:1,b:2,c:3},['a','b']))
  21. //函数
  22. console.log(JSON.stringify({a:1,b:2,c:3},(k,v)=>{
  23. // 将需要过滤掉的数据直接返回undefined
  24. if(v<2) return undefined
  25. return v
  26. }))
  27. // 第三个参数,用来格式化输出的json字符串
  28. console.log(JSON.stringify({a:1,b:2,c:3},null,2))
  29. console.log(JSON.stringify({a:1,b:2,c:3},null,***))
  30. //JSON.parse(str,reviver),将JSON转为JS对象
  31. let obj = JSON.parse(`{"a":1,"b":2,"c":3}`)
  32. console.log(obj,typeof obj)
  33. console.log(obj.a,obj.b,obj.c)\
  34. //第二个参数可以对JSON的数据进行处理后再返回
  35. obj = JSON.parse(`{"a":1,"b":2,"c":3}`,(k,v)=>{
  36. //JSON 对象是由内向外解释
  37. if(k==="") return v
  38. return v*2
  39. })
  40. console.log(obj)
  41. </script>

Ajax 异步请求

特别提示:异步请求不要使用live server 插件,必须创建一个本地服务器

1. 同步与异步

  • 以前前端请求,后端响应为例
    • 同步:前端发请求,必须等到后端响应完成,才允许发送另一个请求
    • 异步:前端发请求后不等待后端响应结果继续执行,后端响应完成通过事件通知前端处理

2. XMLHttpRequest 对象

XMLHttpRequest 是浏览器对象,而非JS内置对象

2.1 xhr 请求步骤

  1. 创建 xhr 对象:const xhr = new XMLHttpRequest()
  2. 配置 xhr 参数:xhr.open(type,url)
  3. 处理 xhr 响应 xhr.onload = (…) => {…}
  4. 发送 xhr 请求:xhr.send(…)

2.2 xhr 对象常用属性

序号 方法 描述
1 responseTyep 设置响应类型
2 response 响应正文

2.3 xhr 对象常用方法

序号 方法 描述
1 open(type,url) 配置请求参数
2 send(data/null) 发送请求

2.4 xhr 对象常用事件

序号 事件 描述
1 load() 请求成功
2 error 请求失败

手册地址
https://developer.mozilla.org/zh-CN/docs/Web/API/xmlhttprequest

3. FormData 对象

FormData表单数据构造器

序号 方法 描述
1 append(name,value) 请求成功
2 delete(name) 请求失败

参考地址
https://developer.mozilla.org/zh-CN/docs/Web/API/FormData

4. get / post 区别

  • get 是url 传参,post 是request body 请求体传参
  • get 回退无影响,post 回退会重复提交
  • get 生成的 url 可做书签,post 不可以
  • get 只能对 url 进行编码,post 支持多种编码
  • get 请求参数会保留再历史记录中,post 参数不保留
  • get 参数长度首先,post 无限制
  • get 只接受 ascii 码字符,post 无限制
  • get post 底层实现是一致的,都是基于 http 协议
  • get 也可以带上 request body, post 也可以带上 url 参数
  • get 产生一个 tcp 数据包,post 产生二个 tcp 数据包
  • get 产生一个请求,post 产生二个请求
  • get 请求,浏览器将 header,data 一起发出,服务器响应 200 成功
  • post 请求,浏览器先发出 header,得到响应 100 continue,再发出data,得到响应 200
  • 并非所有浏览器的post 都产生二次 http 请求,Firefox 就产生一次

5. 跨域

  • CORS : 跨域资源共享
  • 跨域请求可以是get,也可以是post ,只不过get 居多
  • cors-post 时,需要再服务器端进行头部设置
  • jsonp 只能时 get
  1. <script>
  2. // get 请求
  3. const btn = document.querySelector('button')
  4. btn.onclick = () => {
  5. // 1. 创建 xhr 对象
  6. const xhr = new XMLHttpRequest()
  7. // 2. 配置xhr 参数
  8. xhr.open('get', 'php/text1.php?id=2')
  9. xhr.responseType = 'json'
  10. // 3.处理xhr 响应
  11. //成功
  12. xhr.onload = () => {
  13. console.log(xhr.response)
  14. //dom:将响应结果渲染到页面
  15. let user = `${xhr.response.name}(${xhr.response.email})`
  16. document.querySelector('p').innerHTML = user
  17. }
  18. xhr.onerror = () => console.log('Error');
  19. // 4. 发送 xhr 请求
  20. xhr.send(null)
  21. }
  22. </script>

get 请求

  1. // post 请求
  2. <form action="" method="POST" id="login">
  3. <label class="title">用户登录</label>
  4. <label for="email">邮箱:</label>
  5. <input type="email" name="email" id='email'>
  6. <label for="password">密码:</label>
  7. <input type="password" name="password" id='password'>
  8. <button>提交</button>
  9. <span class="tips"></span>
  10. </form>
  11. </body>
  12. <script>
  13. const form = document.querySelector('#login')
  14. const btn = document.querySelector('button')
  15. const tips = document.querySelector('.tips')
  16. btn.onclick = () => {
  17. // ev.preventDefault()
  18. //创建 xhr 对象
  19. const xhr = new XMLHttpRequest()
  20. // 配置 xhr 参数
  21. xhr.open('post', 'php/text2.php')
  22. // 处理 xhr 响应
  23. xhr.onload = () => (tips.innerHTML = xhr.response)
  24. // 发送 xhr 请求
  25. xhr.send(new FormData(form))
  26. }
  27. </script>

post


cors :跨域资源共享

  • 同源策略:为请求安全,浏览器禁止通过脚本发起一个跨域的请求
  • 只允许通过脚本发起基于同源的请求
  • 同源指:协议相同,域名/主机名相同,端口相同
Correcting teacher:天蓬老师天蓬老师

Correction status:qualified

Teacher's comments:是不是觉得ajax非常简单呢?
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post