这是一篇笔记博客,

Ajax:

和服务器进行数据交换(异步)

用js实现复杂的原理:用于发送请求的对象在不同的浏览器中是不同的

同源策略:ajax发送请求的url地址与服务器地址必须是同一域名,协议,端口下

在ajax中常用的一些函数:

open(method,url,async)第三个参数的默认值为true,一般不填写:
send(string):将请求发送到服务器端,post请求填写参数
request.open(“get”,”get.php”,true);request.send()
request.open(“post”,”post.php”,true); request.send()
request.open(“post”,”create.php”,true);
request.setRequestHeader(“Contend-type”,”application/x-www=form-urlencoded”);
request.send(“name=王二狗&sex=男”);
responseText:获得字符串形式的响应数据
responseXML:获得XML形式的响应数据(比较少)
status和statusText:以数字和文本形式返回HTTP状态码
getAllResponseHeader():获取所有响应暴投
getResponseHeader():查询响应中的某个字段的值
 
readystate属性:
0:请求未初始化,open还没有调用
1:服务器连接已建立,open已经调用了
2:请求已接受,也就是接收到了头信息
3:请求处理中,也就是接收到响应主体了
4:请求已完成,且响应已就绪,就是响应完成了
 
xmlhttprequest取得响应:
var reques=new XMLHttpRequest();
request.open("GET","get.php",true);
request.send():
request.onreadystatechange=function(){
if(request.readystate==4&&request.status==200){
//成功之后的函数
}
  1. 原生jsajaxget方法:
  2. var request=new XMLHttpRequest();
  3. request.open('GET','service.php?number='+document.getElementById('keyWord').value);
  4. request.send();
  5. request.onreadystatechange=function(){
  6. if(request.readyState==4&&request.status==200){
  7. document.getElementById('searchResult').innerHTML;
  8. }else{
  9. alert('error!'+request.status);
  10. }
  11. }
  12.  
  13. ajaxpost方法:
  14. var request=new XMLHttpRequest();
  15. request.open('POST','service.php');
  16. var data='name='+document.getElementById('staffName').value
  17. +"&number="+document.getElementById('staffNumber').value
  18. +"&sex="+document.getElementById('staffSex').value
  19. +"&job="+document.getElementById('staffJob').value;
  20. request.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
  21. request.send(data);
  22. request.onreadystatechange=function(){
  23. if(request.readyState==4&&request.status==200){
  24. document.getElementById('createResult').innerHTML;
  25. }else{
  26. alert('error!'+request.status);
  27. }
  28. }
  29. }

上述是不含json的ajax,现在实际操作中基本都是使用json,故什么是json

Json:javascript对象表示法

Json是存储和交换文本信息的语法,类似于XML(长度短小,读写速度更快),它采用键值对的方式来组织,易于人们阅读和编写,同时也易于机器解析和生成

Json是独立于语言的,不管什么语言都可以解析json,只需要按照json的规则来

Json可以使用javascript内建的方法直接解析,转换成javascript对象,

Json数据的书写格式是:名称/值对

名称/值对组合中的名称写在前面(在双引号中),值对写在后面(同样在双引号中),中间用冒号隔开,例如:“name”:“rose”

json的值可以是下面这些类型:

数字(整数或者浮点数)

字符串(在双引号中)

逻辑值(true false)

数组(在方括号中)

对象(在花括号中)

null

例如:

JSON对象:

JSON对象和Js对象中有两个不同:1.没有声明变量 2.没有末尾的分号,对象的属性必须加双引号

例如:

  1. {
  2. "name":"jeo",
  3. "age":,
  4. "school":{
  5. "name":"cq",
  6. "location":"cq"}}

JSON数组:采用数组字面量形式:没有变量和分号

  1. [,'h1',true]

讲数组和对象结合起来:

  1. [
  2. {
  3. "title":"JS",
  4. "authors":[
  5. "NICO"],
  6. edition:,
  7. year:},
  8. {
  9. "title":"CSS",
  10. "authors":["JACK"],
  11. edition:,
  12. year:}]
  1. get方法
  2. var request= new XMLHttpRequest();
  3. request.open("GET","service.php?number="+document.getElementById("keyword").value);
  4. request.send();
  5. request.onreadystatechange=function(){
  6. if(request.readyState==4&&request.status==200){
  7. var data=JSON.parse(request.responseText);
  8. if(data.success){
  9. document.getElementById('searchResult').innerHTML=data.msg;//服务器端的字段
  10. }
  11. else{
  12. document.getElementById('searchResult').innerHTML="出现错误:"+data.msg;
  13. } }
  14. else{
  15. alert('error:'+request.status)
  16. }
  17.  
  18. }
  19. post方法
  20. var request=new XMLHttpRequest;
  21. request.open("POST","service.php");
  22. var data='name:'+document.getElementById('staffName').value+
  23. '&number:'+document.getElementById('staffNumber').value+
  24. '&sex'+document.getElementById('staffSex').value+
  25. '&job'+document.getElementById('staffJob').value;
  26. request.setRequestHeader('content-Type','application/x-www-form-urlencoded');
  27. request.send(data);
  28. request.onreadystatechange=function(){
  29. if(request.readyState==4&&request.status==200){
  30. var data=JSON.parse(request.responseText);
  31. if(data.success){
  32. document.getElementById('createResult').innerHTML=data.msg;
  33. }
  34. else{
  35. document.getElementById('createResult').innerHTML="error:"+data.msg;
  36. }
  37. } else{
  38. alert('error:'+request.status)
  39. }
  40. }

原生js实现ajax与jquery的ajax库,及json的更多相关文章

  1. js原生ajax与jquery的ajax的用法区别

    什么是ajax和原理? AJAX 是一种用于创建快速动态网页的技术. 通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据 XMLHttpRequest对象的基本属性: onre ...

  2. 原生js使用forEach()与jquery使用each遍历数组,return false 的区别

    原生js使用forEach()与jquery使用each()遍历数组,return false 的区别: 1.使用each()遍历数组a,如下: var a=[20,21,22,23,24]; $.e ...

  3. 原生JS研究:学习jquery源码,收集整理常用JS函数

    原生JS研究:学习jquery源码,收集整理常用JS函数: 1. JS获取原生class(getElementsByClass) 转自:http://blog.csdn.net/kongjiea/ar ...

  4. JS原生ajax与Jquery插件ajax深入学习

    序言: 近来随着项目的上线实施,稍微有点空闲,闲暇之时偶然发现之前写的关于javascript原生xmlHttpRequest ajax方法以及后来jquery插件ajax方法,于是就行了一些总结,因 ...

  5. AJAX初识(原生JS版AJAX和Jquery版AJAX)

    一.什么是JSON 1.介绍 JSON独立于语言,是一种与语言无关的数据格式. JSON指的是JavaScript对象表示法(JavaScript Object Notation) JSON是轻量级的 ...

  6. 原生js实现 常见的jquery的功能

    原生选择器   充分利用 bind(this)绑定 <div id="box"> <ul> <li >111 </li> <l ...

  7. 原生JS的使用,包括jquery和原生JS获取节点、jquery和原生JS修改属性的比较

    一.前言 相比于JS这条直达终点.满是荆棘的小路,jquery无疑是康庄大道了,足够的简洁.易用给了它辉煌的地位.然而,毕竟是绕着道的插件,当小路走着走着变成大路的时候,曾经的大路也就失去了他自身的优 ...

  8. 原生js拖拽、jQuery拖拽、vue自定义指令拖拽

    原生js拖拽: <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...

  9. 通过原生js的ajax或jquery的ajax获取服务器的时间

    在实际的业务逻辑中,经常是与时间相关的,而前端能获得的时间有两个:客户端的时间,服务器的时间. 客户端时间通过 javascript中的Date对象可以获取,如 var dt = new Date() ...

随机推荐

  1. web.xml配置重理解

    <context-param> <param-name>home-page</param-name> <param-value>home.jsp< ...

  2. C# 设计模式-策略者模式(Strategy)

    策略模式的用意是针对一组算法,将每一个算法封装到具有共同接口的独立的类中,从而使得它们可以相互替换.策略模式使得算法可以在不影响到客户端的情况下发生变化. 策略模式是对算法的包装,是把使用算法的责任和 ...

  3. Windows系统不同磁盘间的扩容教程

    1.windows系统不同磁盘的空间扩展: https://www.cnblogs.com/yunweis/p/8023098.html

  4. centos7下安装python3.7

    记录在2018年最后一个工作日: Linux环境坑爹得要死,环境本身有python2和python3.7两个版本:安装django2的时候,发现默认是python2:把python软连接到python ...

  5. MySql Delete不走索引问题

    如果delete语句带有查询,写法不对会导致不走索引. 简单粗暴的办法:拆两条sql,一条查询,一条delete ======================= [不走索引的写法] DELETE FR ...

  6. dev16 cxgrid 在DLL里报0地址错

    dev16 cxgrid 在DLL里Form里使用,报0地址错,在EXE里正常.c++builder 的DLL报错,delphi也报错. First chance exception at $09CE ...

  7. 深度学习原理与框架-RNN网络架构-RNN网络 1.RNN的前向传播 2.RNN的反向传播

    对于神经网络而言,每一个样本的输入与输入直接都是独立的,即预测的结果之间并没有联系 而对于RNN而言:不仅仅是有当前的输入,而且上一层的隐藏层也将进行输入,用于进行结果的预测.因此每一个输入都与之前的 ...

  8. 机器学习入门-文本特征-word2vec词向量模型 1.word2vec(进行word2vec映射编码)2.model.wv['sky']输出这个词的向量映射 3.model.wv.index2vec(输出经过映射的词名称)

    函数说明: 1. from gensim.model import word2vec  构建模型 word2vec(corpus_token, size=feature_size, min_count ...

  9. Windows 端口占用解决

  10. linux终端发送邮件

    使用mail: echo "This is message to send" | mail -a /tmp/attachment.txt -s "This is Subj ...