AJAX相关概念及应用
1、Ajax(Asynchronous JavaScript And XML) 异步的JavaScript和XML
XML 可扩展标记语言
Ajax是常用的WEB开发技术,是联系前端和后端的桥梁
应用:搜索引擎(例如在百度里输入一个字符,下面就自动显示相关信息的列表
其实这些信息就是通过使用Ajax从服务器获取的)
2、HTTP原理介绍
HTTP:超文本传输协议
访问网页的原理:响应 和 请求
请求:从客户端到服务器端的请求消息
响应:服务器根据客户请求返回内容
请求方式:get 和 post
get方式请求:需要从服务器获取数据
post方式请求:把客户端的数据提交给服务器
总结:Ajax就是通过运行JavaScript程序发起HTTP请求,而不用非得把请求地址写到
浏览器地址栏,再按回车请求网页
3、Chrome浏览器开发者工具
可以通过Network选项查看发起的请求
3、搭建自己的WEB服务器
如何让自己的电脑变成服务器:安装WEB服务器程序
最常用的WEB服务器程序是Apache,但是在Windows环境下安装会比较困难,所以
可以安装一个集成环境:XAMPP(下载地址:http://www.xampps.com)
本机的IP地址:127.0.0.1 等同于域名 localhost
将网页放到XAMPP安装根目录下htdocs文件夹下
4、Ajax使用步骤
(1)创建XMLHttpRequest对象
var xhr = new XMLHttpRequest();
(2)使用onreadystatechange事件监听请求过程的变换,并设置匿名函数处理响应内容
readyState状态0-4
0:请求初始化
1:服务器建立连接
2:收到的请求
3:处理请求
4:请求完成并准备响应就绪
(3)初始化请求
xhr.open()
(4)发送请求
xhr.send()
5、XMLHttpRequest对象
属性:
onreadeystate事件
readyState XMLHttpRequest对象的状态码,从0-4变化
0:请求初始化
1:服务器建立连接
2:收到的请求
3:处理请求
4:请求完成和响应准备就绪
status HTTP状态码,例如404/200/500
responseText 返回作为一个字符串的响应数据
方法:
open(method,url,asyn)
send()
setRequestHeader()仅在post请求时使用
xhr.setRequestHeader("Content-Type","aplication/x-www-form-urlencoded");
==============以下使用表单方式和Ajax方式请求区别==============
表单方式:地址栏会跳转
Ajax方式:地址不会跳转
6、表单GET请求与POST请求的区别
GET请求会将数据拼接显示在地址栏中,不安全。且地址栏地址的长度是有限制的,超出长度,地址失效
POST请求方式不会将数据显示在地址栏,相对get方式更安全
7、Ajax发起GET请求
document.querySelector('#getBtn').onclick = function(){
var name = document.getElementById('name').value;
var message = document.getElementById('message').value;
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
if(xhr.status === 200 && xhr.readyState === 4){
alert(xhr.responseText);
}
}
xhr.open('GET','http://localhost/get-content.php?name='+ name +'&message='+ message +'',true);
xhr.send();
}
8、Ajax发起POST请求
document.querySelector('#postBtn').onclick = function(){
var name = document.getElementById('name').value;
var message = document.getElementById('message').value;
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
if(xhr.status === 200 && xhr.readyState === 4){
alert(xhr.responseText);
}
}
xhr.open('POST','http://localhost/post-content.php',true);
xhr.setRequestHeader('Content-Type','Application/x-www-form-urlencoded');
xhr.send('name='+ name +'&message='+ message);
}
9、Ajax处理JSON数据
JSON(JavaScript Object Notation,JS对象标记)是一种轻量级的数据交换格式
后端可能是php、java、.net,不管后端是什么,只要知道后端会返回一个JSON数据即可。
实际中可以根据后端提供的接口来获取JSON,再在前端进行相关操作。
JSON.parse() 可以把JSON字符串转换为JavaScript对象
10、Ajax异步和同步
同步:后面的代码必须等到Ajax请求完成后才执行
异步:后面的代码会先于Ajax请求执行
一个程序中,异步操作会等到同步操作执行完成后才执行
AJAX相关概念及应用的更多相关文章
- 从零开始学 Web 之 Ajax(一)服务器相关概念
大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...
- AJAX学习前奏----JS基础加强
AJAX学习前奏----JS基础加强 知识概要: 1.js类&属性&方法的定义 2.静态属性与方法 3.构造方法 4.原型的使用 5.Object对象直接加属性和方法 6.JSO ...
- 什么是 dynaTrace Ajax
随着 jQuery.Dojo.YUI 等框架的兴起让构建 Web2.0 应用更加容易,但随之带来的定位等应用问题也越来越难,尤其是与性能相关的.dynaTrace Ajax Edition 是一个强大 ...
- ActiveMQ使用详解---相关概念
一.前言 公司之前使用activeMQ做过一款用于系统之间传递信息的工具,最近才正式投入生产使用,这期间出现了一些比较奇怪的问题,最终发现是没有清晰的了解activeMQ的相关配置以及一些相关概念,借 ...
- Ajax和跨域请求
Ajax 一.概述 Web 程序最初的目的就是将信息(数据)放到公共的服务器,让所有网络用户都可以通过浏览器访问. 在次之前,我们可以通过以下几种方式让浏览器发出对服务端的请求,获取服务端的数据: 地 ...
- 纯手写实现ajax分页功能
前言 最近用到了这个功能,百度大半天,网上的不是有各种问题就是需要引入其他的插件,无奈,只能自己写,大致功能已经完成.前端页面用bootstrap做样式,分页功能用ajax实现,没用其他插件哦,只引入 ...
- jQuery之ajax实现篇
jQuery的ajax方法非常好用,这么好的东西,你想拥有一个属于自己的ajax么?接下来,我们来自己做一个简单的ajax吧. 实现功能 由于jq中的ajax方法是用了内置的deferred模块,是P ...
- Ajax及跨域
概念 Ajax Ajax,Asynchronous JavaScript and XML,字面意思:异步的 JavaScript 和 XML,是指一种创建交互式网页应用的网页开发技术. 用于异步地去获 ...
- 一个粗心的Bug,JSON格式不规范导致AJAX错误
一.事件回放 今天工作时碰到了一个奇怪的问题,这个问题很早很早以前也碰到过,不过没想到过这么久了竟然又栽在这里. 当时正在联调一个项目,由于后端没有提供数据接口,于是我直接本地建立了一个 json ...
随机推荐
- NX二次开发-对话框加锁UF_UI_lock_ug_access
VC/MFC调用UG Dialog要进入加锁状态 加锁 UF_UI_lock_ug_access ( UF_UI_FROM_CUSTOM ); 此处为UF_UI_select的函数 解锁 UF_UI_ ...
- ionic:创建 APP
ylbtech-ionic:创建 APP 1.返回顶部 1. ionic 创建 APP 前面的章节中我们已经学会了 ionic 框架如何导入到项目中. 接下来我们将为大家介绍如何创建一个 ionic ...
- 去掉Word 标题编号变成黑框
问题: 在使用Word编写文档时,提前拟好的标题编号会突然变成黑框(黑色的方框,黑色的矩形),如下图 解决方案: 1.将光标定位到标题中,紧邻黑框的右侧 2.按键盘左方向键使方框变成黑色 3.按键盘的 ...
- liunx crontab 参数代表含义
* * * * * (下面的字体对应) 分钟 小时 几号 月份 星期几 星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作. 逗号(,): ...
- Qt学习笔记----信号与槽实现的四种方式
1.以按钮为例,首先添加一个按钮,对象名为pushButton,在按钮是右键单击选择“转到槽”即可,在转到槽选择面板(右图)里面选择需要进行的操作,比如单击clicked() 2.选择菜单“编辑”,找 ...
- java 打印1到n之间的整数
package java_day08; /* * 打印1-n之间的整数 * * 递归:方法体自己调用自己 */ public class DiGui { public static void main ...
- x25, PF_X25 - ITU-T X.25 / ISO-8208 协议接口。
总览 #include <sys/socket.h> #include <linux/x25.h> x25_socket = socket(PF_X25, SOCK_SEQPA ...
- Estimation
Estimation 给出一个长度为n序列\(\{a_i\}\),将其划分成连续的K段,对于其中一段\([l,r]\),设其中位数为m,定义其权值为\(\sum_{i=l}^r|m-a_i|\),求最 ...
- uoj49 轴仓库
题意: n叠箱子排成一线,第i叠箱子坐标为xi,竖直方向叠着ai个箱子. 可以花费+1s左移或右移一位,也可以在瞬间搬起一个位置的箱子,或将怀里的有且仅有一个箱子放下. 任意选择起点s(可以不与xi重 ...
- Windows taskkill
TASKKILL [/S system [/U username [/P [password]]]] { [/FI filter] [/PID processid | /IM imag ...