当前位置: 首页 > news >正文

jQuery与ajax应用

jQuery对ajax进行了封装,其中$.ajax()方法属于最底层方法,第2层是load()、$.get()和$.post()方法,第三层是$.getScript()和$.getJSON方法。

一、$.ajax(options)

该方法只有1个参数,所有参数以key/value形式存在,所有参数都是可选的。

url 发送请求的地址,默认为当前页地址

type 请求方式post或get,默认为get.

timeout  设置请求超时时间,此设置覆盖$.ajaxSetup()方法的全局设置

data 发送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData 选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2'。

dataType 

预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML。在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script 则会执行这个脚本。随后服务器端返回的数据会根据这个值解析后,传递给回调函数。可用值:

  • "xml": 返回 XML 文档,可用 jQuery 处理。
  • "html": 返回纯文本 HTML 信息;包含的 script 标签会在插入 dom 时执行。
  • "script": 返回纯文本 JavaScript 代码。不会自动缓存结果。除非设置了 "cache" 参数。注意:在远程请求时(不在同一个域下),所有 POST 请求都将转为 GET 请求。(因为将使用 DOM 的 script标签来加载)
  • "json": 返回 JSON 数据 。
  • "jsonp": JSONP 格式。使用 JSONP 形式调用函数时,如 "myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。
  • "text": 返回纯文本字符串

beforeSend 

发送请求前可修改 XMLHttpRequest 对象的函数,如添加自定义 HTTP 头。

XMLHttpRequest 对象是唯一的参数。

这是一个 Ajax 事件。如果返回 false 可以取消本次 ajax 请求。

function(XMLHttpRequest){this;//调用本次ajax传递的option参数}

complete 

请求完成后回调函数 (请求成功或失败之后均调用)。

参数: XMLHttpRequest 对象和一个描述请求类型的字符串。

这是一个 Ajax 事件。function(XMLHttpRequest,textStatus){this;//调用本次ajax传递的option参数}

success 请求成功后调用的回调函数,有两个参数。

(1)由服务器返回,并根据dataType参数济宁处理后的数据。

(2)描述状态的字符串。function(data,textStatus){data,this}

error 请求失败时被调用的函数,有三个参数,XMLHttpRequest,textStatus,errorThrown

global 默认为true,是否触发全局ajax事件,

例:

$(function(){
$('#send').click(function(){
$.ajax({
type: "GET",
url: "test.json",
data: {username:$("#username").val(), content:$("#content").val()},
dataType: "json",
success: function(data){
$('#resText').empty(); //清空resText里面的所有内容
var html = '';
$.each(data, function(commentIndex, comment){    //each() 方法规定为每个匹配元素规定运行的函数。
html += '<div class="comment"><h6>' + comment['username']
+ ':</h6><p class="para"' + comment['content']
+ '</p></div>';
});
$('#resText').html(html);
}
});
});
});

二.load(),$.get(),$.post()

1.load()

load() 方法通过 AJAX 请求从服务器加载数据,并把返回的数据放置到指定的元素中。

语法load(url [,data] [,callback])

url 请求Html页面的url地址

data 可选 发送给服务器的key/value数据

callback可选 请求完成时的回调函数,无论成功与否。例:

1.载入html.

$("#result").load("ajax/test.html", function() { alert("Load was performed."); });


2.筛选载入的html文档

$("#result").load("ajax/test.html  .para")

3.传递方式

根据data来自动选择,没有参数则用get方法,有则转换为post

例:$("#result").load("ajax/test.html  .para" ,{name:"lla"},function(){})//get方法

4.回调参数

$("#result").load("ajax/test.html  .para" ,{name:"lla"},function(responseText,textStatus,XMLHttpRequest){})  //三个参数分别表示请求返回文本,请求状态 :success,error,notmodified,timeout.,xmlhttprequest对象

2.$.get() 语法 $.get(url[,data][,callback][,type])

3.$.post()

4.$.getScript()用来直接加载一个js文件

jQuery.getScript(url,success(response,status))

5.$.getJSON 用来加载一个JSON

以上2345都是基于1构建的。

转载于:https://www.cnblogs.com/cumting/p/6784341.html

相关文章:

  • [Python基础]Python文件处理小结
  • Android攻城狮Notification实现状态通知栏
  • Atitit 错误处理机制:(1)静默模式(2)警告模式 (3)异常模式
  • 深刻认识shift_ram IP core——图像处理学习笔记
  • 实现简单的ORM
  • python基本运算
  • 备份一下我的.bash_aliases文件
  • vue.js 的起步
  • Bullet Physics OpenGL 刚体应用程序模板 Rigid Simulation in Bullet
  • Unity Shader-简单均值模糊
  • webpack-dev-server 设置反向代理解决跨域问题
  • CF364
  • jsp相关笔记(二)
  • CPU组成
  • 【Java并发编程】:加锁和volatile变量
  •  D - 粉碎叛乱F - 其他起义
  • Fundebug计费标准解释:事件数是如何定义的?
  • Git的一些常用操作
  • JS实现简单的MVC模式开发小游戏
  • Linux中的硬链接与软链接
  • MySQL主从复制读写分离及奇怪的问题
  • nginx 负载服务器优化
  • NLPIR语义挖掘平台推动行业大数据应用服务
  • storm drpc实例
  • Travix是如何部署应用程序到Kubernetes上的
  • Vue 重置组件到初始状态
  • 百度贴吧爬虫node+vue baidu_tieba_crawler
  • 彻底搞懂浏览器Event-loop
  • 大数据与云计算学习:数据分析(二)
  • 工作中总结前端开发流程--vue项目
  • 配置 PM2 实现代码自动发布
  • 全栈开发——Linux
  • 山寨一个 Promise
  • 跳前端坑前,先看看这个!!
  • 为视图添加丝滑的水波纹
  • 中文输入法与React文本输入框的问题与解决方案
  • 【干货分享】dos命令大全
  • ​LeetCode解法汇总1410. HTML 实体解析器
  • #我与Java虚拟机的故事#连载05:Java虚拟机的修炼之道
  • $redis-setphp_redis Set命令,php操作Redis Set函数介绍
  • (1)(1.9) MSP (version 4.2)
  • (4) openssl rsa/pkey(查看私钥、从私钥中提取公钥、查看公钥)
  • (4) PIVOT 和 UPIVOT 的使用
  • (BFS)hdoj2377-Bus Pass
  • (poj1.3.2)1791(构造法模拟)
  • (第二周)效能测试
  • (附源码)springboot课程在线考试系统 毕业设计 655127
  • (每日持续更新)信息系统项目管理(第四版)(高级项目管理)考试重点整理第3章 信息系统治理(一)
  • (三)终结任务
  • (十八)SpringBoot之发送QQ邮件
  • (原创)攻击方式学习之(4) - 拒绝服务(DOS/DDOS/DRDOS)
  • .gitignore文件设置了忽略但不生效
  • .net core 3.0 linux,.NET Core 3.0 的新增功能
  • .NET Core 中的路径问题
  • .net php 通信,flash与asp/php/asp.net通信的方法