ajax异步 —— javascript
目录
ajax是什么
作用:不必重新加载整个页面,更新部分页面内容。
大概使用过程:通过后台提供的数据接口,ajax获取数据,动态修改视图层。
原生ajax
将ajax请求封装成一个函数,可以传参,选择请求类型,以及成功后的回调函数。
- /*
- url: 请求地址,
- data: 请求参数,
- method: 请求类型,
- success: 请求成功后的回调函数
- */
- function ajax_method(url, data, method, success){
- var ajax;
- if (window.XMLHttpRequest) {
- // IE7+, Firefox, Chrome, Opera, Safari
- ajax = new new XMLHttpRequest();
- }else {
- // IE6, IE5
- ajax = new ActiveXObject("Microsoft.XMLHTTP");
- }
- if (method == "get") {
- if (data) {
- // 有数据
- url += ("?"+data);
- }
- ajax.open(method, url);
- ajax.send();
- }else{
- // post
- ajax.open(method, url);
- // post请求要加上的请求头
- ajax.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
- if (data) {
- ajax.send(data);
- }else{
- ajax.send();
- }
- }
- ajax.onreadystatechange = function(){
- console.log("可以1");
- // 0: 请求未初始化
- // 1: 服务器连接已建立
- // 2: 请求已接收
- // 3: 请求处理中
- // 4: 请求已完成,且响应已就绪
- // 200: 请求处理成功
- // 404: 未找到页面
- if (ajax.readyState == 4 && ajax.status == 200) {
- console.log("请求成功");
- success(ajax.responseText);
- }else{
- console.log("请求失败");
- }
- }
- }
调用:
- ajax_method("./test.php", {"param1": "val1"}, "post", function(data){
- console("请求拿到的数据:",data);
- // 之后将拿到的数据渲染视图层
- })
jquery ajax
使用jqury,可以便捷的发送ajax请求,需要引入juery.js
- $.ajax({
- url: "./test.php",
- method: "post",
- dataType: "json", // 服务器返回数据类型
- data: {
- "param1": "val1", // 请求参数
- },
- success: function(data){
- console("请求拿到的数据:",data);
- // 之后将拿到的数据渲染视图层
- },
- error: function(){
- alert('请求失败');
- }
- });
ajax跨域
为什么有跨域问题?
“同源策略限制了从同一个源加载的文档或脚本如何与来自另一个源的资源进行交互。这是一个用于隔离潜在恶意文件的重要安全机制。”
同源:相同协议,域名,端口号。
所以当ajax请求的地址,存在协议,域名,端口号不同时,则存在跨域问题,浏览器会报错。
解决跨域的方法,可以看下一篇文章。
ajax异步 —— javascript的更多相关文章
- Ajax异步验证登陆或者注册
首先介绍一个不错的学习Ajax的中文网站:http://www.w3school.com.cn/ajax/index.asp AJAX = 异步 JavaScript 和 XML.详细介绍见上面的网址 ...
- Scrapy爬虫框架教程(四)-- 抓取AJAX异步加载网页
欢迎关注博主主页,学习python视频资源,还有大量免费python经典文章 sklearn实战-乳腺癌细胞数据挖掘 https://study.163.com/course/introduction ...
- How to make an HTTP request 异步 JavaScript 和 XML
https://developer.mozilla.org/en-US/docs/AJAX/Getting_Started In order to make an HTTP request to th ...
- js(三) ajax异步局部刷新技术底层代码实现
ajax 异步 javaScript and xml 开发五步骤: 1. 创建对象 XMLHttpRequest(chrome,firefox) ie... jquery 2. 找到连接, http的 ...
- 【JavaScript】AJAX总结(异步JavaScript和XML)
AJAX介绍 通过 AJAX,你可以创建更好.更快以及更友好的 WEB 应用程序. AJAX 基于 JavaScript 和 JavaScript的XMLHttpRequest对象. AJAX 应用程 ...
- [转] 为什么javascript是单线程的却能让AJAX异步调用?
为什么JavaScript是单线程的却能让AJAX异步发送和回调请求,还有setTimeout也看起来像是多线程的? function foo() { console.log( 'first' ); ...
- ajax异步请求
做前端开发的朋友对于ajax异步更新一定印象深刻,作为刚入坑的小白,今天就和大家一起聊聊关于ajax异步请求的那点事.既然是ajax就少不了jQuery的知识,推荐大家访问www.w3school.c ...
- ASP.NET知识总结(8.AJAX异步)
AJAX:”Asynchronous JavaScript and XML” 中文意思:异步JavaScript和XML. 指一种创建交互式网页应用的网页开发技术. 不是指一种单一的技术,而是有机 ...
- 淘宝购物车页面 智能搜索框Ajax异步加载数据
如果有朋友对本篇文章的一些知识点不了解的话,可以先阅读此篇文章.在这篇文章中,我大概介绍了一下构建淘宝购物车页面需要的基础知识. 这篇文章主要探讨的是智能搜索框Ajax异步加载数据.jQuery的社区 ...
随机推荐
- is == 编码与解码
is 和 == 主要是数字和字符串的比较 1 区别: ==比较的是两边的值 is比较的是两边值的id id获取的方法 id() 2 小数据池: -5~256 3 字符串中特殊字符有id ...
- C++入门经典-例5.16-输出引用
1:如不加特殊说明,一般认为引用指的都是左值引用.引用实际上是一种隐式指针,它为对象建立一个别名,通过操作符&来实现,引用的形式如下: 数据类型 & 表达式: 例如: int a=10 ...
- 非对称加密算法DH
特点: 发送方和接收方均有一个密钥对(公钥+私钥),其中公钥传播,私钥自己保存,不需要传播 私钥不需要传播的特性解决了对称加密算法中密钥传播的困难(这个困难一般通过线下传递可以解决) 加密安全性极高, ...
- 数据加密之AES
特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...
- idea maven sync Cannot resolve xxx 的解决方案
经常会出现这种奇葩情况,提示找不到包 其实是因为网络波动或者突然断掉,导致包更新出现问题 直接去maven的仓库目录 找到不能找到的包 删掉相关目录 然后重新更新maven就行了 比如 直接去仓库目录 ...
- 191016Django基础
一.简单的webserver框架 from wsgiref.simple_server import make_server def login(req): #view函数 print(req[&qu ...
- Oracle数据表之间的数据同步
保证两个数据表结构相同,如不相同只能同步相同字段; 只是思路,具体请根据需求修改. declare cursor csrn_mon is select * from table2; row_mon c ...
- Input 输入框
Input 输入框 通过鼠标或键盘输入字符 <el-input v-model="input" placeholder="请输入内容"></e ...
- vim命令行模式常见快捷方式
普通模式下的快捷键 快捷键 说明 i insert, 在光标所在处输入 I 在当前光标所在行的行首输入 a append, 在光标所在处后面输入 A 在当前光标所在行的行尾输入 o 在当前光标所在行的 ...
- linux 下载jdk 、maven、git
jdk: wget --no-check-certificate --no-cookies --header "Cookie: oraclelicense=accept-secureback ...