数据交互

一、http协议

  • 基本特点

    • 1、无状态的协议
    • 2、连接过程:发送连接请求、响应接受、发送请求
    • 3、消息分两块:头、体
  • http和https

二、form

  • 基本属性

    • action——提交到哪儿
    • method——GET/POST/PUT/DELETE/HEAD
      • GET:获取数据、把数据放在url里面传输、数据量很小、有缓存
      • POST:发送数据、把数据放在body里面传输、数据量大、不会缓存
      • PUT:发送数据
      • DELETE:删除数据
      • HEAD:让服务器之发送头回来就行(不需要内容)
    • name:提交数据的名字
    • enctype
      • application/x-www-form-urlencoded:默认值,适合发送小数据,结构 名字=值&名字=值&...
      • multipart/form-data:文件上传、大数据,结构 分块
      • text/plain

三、ajax

  • 原理 XMLHttpRequest,不兼容IE6

    • 1.创建对象
    • 2.连接
    • 3.发送
    • 4.接受
        function ajax (){
      2 // 1.创建对象
      3 let xhr = new XMLHttpRequest();
      4 // 2.连接
      5 /*
      6 * open(method,url,async):规定请求的类型、URL 以及是否异步处理请求
      7 * method:请求的类型;GET 或 POST
      8 * url:文件在服务器上的位置
      9 a * sync:true(异步)或 false(同步)
      10 */
      11 xhr.open('GET','./data/1.txt',true);
      12 // 3.发送
      13 /*
      14 * send(string):将请求发送到服务器
      15 * string:仅用于 POST 请求
      16 *
      17 * setRequestHeader(header,value):向请求添加 HTTP 头
      18 * header: 规定头的名称
      19 * value: 规定头的值
      20 */
      21 xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
      22 xhr.send(null)
      23 // 4.接受
      24 /*
      25 * responseText:获得字符串形式的响应数据
      26 * responseXML:获得 XML 形式的响应数据
      27 *
      28 * onreadystatechange:存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数
      29 *
      30 * readyState:存有 XMLHttpRequest 的状态。从 0 到 4 发生变
      31 * 0: 请求未初始化
      32 * 1: 服务器连接已建立
      33 * 2: 请求已接收
      34 * 3: 请求处理中
      35 * 4: 请求已完成,且响应已就绪
      36 *
      37 * status
      38 * 200: "OK"
      39 * 404: 未找到页面
      40 */
      41 xhr.onreadystatechange = function () {
      42 if (xhr.readyState == 4) {
      43 if (xhr.status>=200 && xhr.status<300 || xhr.status == 304) {
      44 alert(xhr.responseText)
      45 }else{
      46 alert('error:'+xhr.status)
      47 }
      48 }
      49 }
      50 }

      原生ajax

  • 优点

    • 用户体验好
    • 性能高
  • 安全

    • 前台没有安全性,后台才有问题(注入)
    • xss——跨站脚本攻击
  • ajax 2.0

    • FormData
    • 文件上传、上传进度监控
    • CORS跨域

四、jsonp

  • 原理

五、websocket

web全栈架构师[笔记] — 02 数据交互的更多相关文章

  1. web全栈架构师[笔记] — 03 html5新特性

    HTML5新特性 一.geolocation PC端 精度比较低 通过IP库定位 移动端 通过GPS window.navigator.geolocation 单次 getCurrentPositio ...

  2. web全栈架构师[笔记] — 01 ECMAScript6新特性

    ES6新特性 一.变量 var:重复定义不报错:没有块级作用域:不能限制修改 let:变量,不能重复定义,有块级作用域 const:常量,不能重复定义,有块级作用域 二.函数/参数 箭头函数——简写: ...

  3. 2019最新WEB全栈架构师第八期视频教程

    下载链接:https://www.yinxiangit.com/117.html

  4. 22期老男孩Ptython全栈架构师视频教程

    老男孩Ptython全栈架构师视频教程 Python最新整理完整版22期视频教程 超60G课程容量<ignore_js_op> <ignore_js_op> <ignor ...

  5. 添物零基础到大型全栈架构师 Java实战及解析(实战篇)- 概述

    ​ 实战篇是在基础之上,进一步提升的内容.通过实战篇可以深入理解Java相关框架和库的使用,能够独立开发小模块,或者按照架构师的指导进行代码编写和完善. 主要讲解核心框架和库的使用和使用场景介绍.通过 ...

  6. Kubernetes全栈架构师(基本概念)--学习笔记

    目录 为什么要用Kubernetes? K8s控制节点-Master概念 K8s计算节点-Node概念 什么是Pod? 为什么要引入Pod? 创建一个Pod 零宕机发布应用必备知识:Pod三种探针 零 ...

  7. Kubernetes全栈架构师(Kubeadm高可用安装k8s集群)--学习笔记

    目录 k8s高可用架构解析 Kubeadm基本环境配置 Kubeadm系统及内核升级 Kubeadm基本组件安装 Kubeadm高可用组件安装 Kubeadm集群初始化 高可用Master及Token ...

  8. Kubernetes全栈架构师(资源调度上)--学习笔记

    目录 Replication Controller和ReplicaSet 无状态服务Deployment概念 Deployment的创建 Deployment的更新 Deployment的回滚 Dep ...

  9. Kubernetes全栈架构师(二进制高可用安装k8s集群部署篇)--学习笔记

    目录 二进制高可用基本配置 二进制系统和内核升级 二进制基本组件安装 二进制生成证书详解 二进制高可用及etcd配置 二进制K8s组件配置 二进制使用Bootstrapping自动颁发证书 二进制No ...

随机推荐

  1. samba 配置文件解析

    [global] #定义全局策略 workgroup=MYGROUP #定义工作组 netbios name=MYSERVER #指定NetBios名称 interfaces=lo 192.168.1 ...

  2. 程序猿的日常——工作中常用的Shell脚本

    工作当中总是会有很多常用的linux或者命令,这里就做一个总结 文件远程拷贝 如果想把文件从本机拷贝到远程,或者从远程下载文件到本地. # 把本地的jar拷贝到远程机器xxxip的/home/sour ...

  3. Android 富文本编辑器实现方案

    本人实现富文本编辑器的时候,总结了如下两种方案: 1. 纯 EditText 实现方案 2. 使用ScrollView作为最外层的父容器来控制展示效果 示例demo地址为:https://github ...

  4. react小知识2

    概述 这是我学习react的过程中,学到的一些简便写法,都是利用了es6的特性,记录下来供以后开发时参考,相信对其他人也有用. 参考资料:dva.js 知识导图 析构 我们也可以析构传入的函数参数. ...

  5. php省市联动实现

    设计模式:ajax实现,数据库格式:id,name,parent_id 数据库: CREATE TABLE IF NOT EXISTS `city` ( `id` ) NOT NULL AUTO_IN ...

  6. LeetCode:105_Construct Binary Tree from Preorder and Inorder Traversal | 根据前序和中序遍历构建二叉树 | Medium

    要求:通过二叉树的前序和中序遍历序列构建一颗二叉树 代码如下: struct TreeNode { int val; TreeNode *left; TreeNode *right; TreeNode ...

  7. 【2019北京集训2】Elephant 平衡树

    题目大意:给你一个长度为$n$的序列$A_i$,有$q$次操作,每次操作为以下三种之一: 询问区间的$F_M(A_i)$的最大公约数. 区间翻转,区间加一个正数. 我们定义$gcd(0,0)=0$,且 ...

  8. hdu 6058---Kanade's sum(链表)

    题目链接 Problem Description Give you an array A[1..n]of length n. Let f(l,r,k) be the k-th largest elem ...

  9. 理解Array.prototype.fill和Array.from

    之所以将这两个方法放在一起说,是因为经常写这样的代码: Array.from({length: 5}).fill(0),看起来很简洁,但是踩到坑之后才发现自己对这两个方法实在是不求甚解. Array. ...

  10. 全网最详细的实用的搜索工具Listary和Everything对比的区别【堪称比Everything要好】(图文详解)

    不多说,直接上干货! 引言 无论是工作还是科研,我们都希望工作既快又好,然而大多数时候却迷失在繁杂的重复劳动中,久久无法摆脱繁杂的事情.   你是不是曾有这样一种想法:如果我有哆啦A梦的口袋,只要拿出 ...