Ajax?!!


其实我想完整的总结一下前端网络的那些东西,但我想不到题目了啊。
就从Ajax开始说吧...

最近玻尿酸鸭很火,先卖个萌吧

Ajax是什么?

曾经,我们每发送一个请求,都要重新加载一下页面。二璇妹妹很小很小时候登录某小游戏网站,输入了账号,但输错了密码,于是乎页面刷新了,还要重新输入用户名,体验贼次啊,好气。

2005年,google地图放大或移动时,做到了不刷新页面就显示新的信息,众人大呼 “哇,这是好棒~~”,嗯,Ajax就风靡起来了。

Ajax Asynchronous Javascript And XML(异步JavaScript和XML),是一种不刷新整个网页就与服务器通讯的办法,数据在客户端与服务器之间独立传输,服务器返回的不再是整个界面。

Ajax的x指的是 xml,曾经Ajax以异步形式操作的是 xml,现在Ajax操作的是Json


Form表单

上面那个让二璇妹妹很气的事就可能是用form表单提交的信息。那么我们来了解一下吧!

传统的form表单主要有三个重要的属性

  • method:GET / POST请求

  • action:后台文件地址

  • enctype:
    application/x-www-form-urlencoded 在发送前编码所有字符(默认情况下)
    multipart/form-data 不对字符进行编码(<input type='file'> 主要用于表单上传文件时)

    form表单中method属性 GET ,POST

  • GET 使用URL 或Cookie 传参,而POST将数据,放在BODY中。

  • GET 的URL会有长度上的限制, POST可以传输很多数据。
    但事实上HTTP协议对GET和POST 都没有对数据的长度进行限制,只是浏览器限制了URL的长度

  • POST比GET安全。
    因为GET的参数直接暴露在url上,并且会完整保留在浏览器历史记录里

  • GET产生一个TCP数据包,POST产生两个TCP数据包
    对于GET请求,浏览器会把http header和data一并发送出去,服务器响应200。而对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200


Ajax的优点

1.页面无刷新与服务器通信

2.以异步形式与服务器通信,不需要打断用户操作。

3.减轻服务器的负担。

Ajax的缺点

1.破坏浏览器的后退机制。
动态更新页面的情况下,用户无法回到前一个页面状态

2.安全问题
会暴露比以前更多的数据和服务器逻,遇到跨站点脚本攻击、sqi注入攻击问题。

3.对搜索引擎支持较弱(seo)。

4.在移动端兼容性比较差

5.违背了url和资源定位的初衷。
一个url如果采用了ajax技术,也许在该url地址下面看到的和别人在这个url地址下看到的内容是不同的。这个和资源定位的初衷是相背离的。


还是先说几个重要的参数

对象上三个很重要的方法:

  • **.open(‘method’, ‘url’, ‘true’) **
    建立对服务器的调用,method参数可以是get、post或者put。
    url参数可以是相对url或者绝对url。
    第三个参数是选择异步还是同步,异步是true。
  • **.send(content) **
    向服务器发送请求
  • **.setRequestHeader(‘label’, ‘value’) **
    把指定首部设置为提供的值,在设置任何首部之前必须调用open方法。
    对象的属性
  • onreadystatechange
    状态改变触发器
  • readyState
    对象的状态
    0代表未初始化,此时已经创建了一个XMLHttpRequest对象
    1代表读取中,此时代码已经调用XMLHttpRequest的open方法并且XMLHttpRequest已经将请求发送到服务期。
    2代表已读取,此时已经通过open方法把一个请求发送到服务端,但是还没有收到。
    3代表交互中,此时已经收到http响应头部信息,但是消息主体部分还没有完全接受
    4代表完成,此时响应已经被完全接受。
  • responseText
    服务器进程返回数据的文本版本
  • responseXML
    服务器进程返回数据的兼容DOM的XML文旦对象
  • status 服务器返回的状态码

让我们来封装一个Ajax吧

   function Ajax(method,url,flag,data,callBack){
    /* 创建对象*/
            var xhr = null;
            if(window.XMLHttpRequest){//用对象访问,即使没有该属性也是返回undefined不会报错。
                xhr = new window.XMLHttpRequest();//与后台服务器交换数据
            }else{
                xhr = new window.ActiveXObject('Microsoft.XMLHTTP');//兼容ie浏览器
            }   
    /*创建与服务器的连接*/
            if(method === 'GET'){
                xhr.open('GET',url + '?' + data, flag);//建立与服务器的连接,flag表示是否异步
                xhr.send();//向服务器发送请求
            }else if(method === 'POST'){
                xhr.open('POST',url,flag);
                xhr.setRequestHeader('Content-type','application/x-www.form-urlencoded');//设置发送数据格式
                xhr.send(data);
            }
    /*实时监听对象状态*/
            xhr.onreadystatechange = function(){//状态改变事件触发器
                if(xhr.readyState === 4){
                    if(xhr.status === 200){
                        callBack(xhr.responseText);
                    }else{
                        alert('error'); 
                    }
                }
            }               
     }

好吧,我有点懒得解释每个函数,就简单的注释一下。。。
readyState 和 status放在http里说吧,✌️


同源策略

同源策略(Same-Origin Policy)只有在域名协议名端口号都相同的情况下,才称为同源。

不同源的客户端脚本在没有明确授权的情况下,是不能够读写对方的资源的。

~~~哦,我们得了解一下什么是域名协议名端口号

url(资源定位器)的构成

(原文:http://blog.csdn.net/ergouge/article/details/8185219

http://www.aspxfans.com:8080/news/index.asp?boardID=5&ID=24618&page=1#name

从上面的URL可以看出,一个完整的URL包括以下几部分:
1.协议部分
该URL的协议部分为“http:”,这代表网页使用的是HTTP协议。在Internet中可以使用多种协议,如HTTP,FTP等等本例中使用的是HTTP协议。在"HTTP"后面的“//”为分隔符
2.域名部分
该URL的域名部分为“www.aspxfans.com”。一个URL中,也可以使用IP地址作为域名使用
3.端口部分
跟在域名后面的是端口,域名和端口之间使用“:”作为分隔符。端口不是一个URL必须的部分,如果省略端口部分,将采用默认端口
4.虚拟目录部分
从域名后的第一个“/”开始到最后一个“/”为止,是虚拟目录部分。虚拟目录也不是一个URL必须的部分。本例中的虚拟目录是“/news/”
5.文件名部分
从域名后的最后一个“/”开始到“?”为止,是文件名部分,如果没有“?”,则是从域名后的最后一个“/”开始到“#”为止,是文件部分,如果没有“?”和“#”,那么从域名后的最后一个“/”开始到结束,都是文件名部分。本例中的文件名是“index.asp”。文件名部分也不是一个URL必须的部分,如果省略该部分,则使用默认的文件名
6.锚部分
从“#”开始到最后,都是锚部分。本例中的锚部分是“name”。锚部分也不是一个URL必须的部分
7.参数部分
从“?”开始到“#”为止之间的部分为参数部分,又称搜索部分、查询部分。本例中的参数部分为“boardID=5&ID=24618&page=1”。参数可以允许有多个参数,参数与参数之间用“&”作为分隔符。

  • 域名是倒着解析的
    举个栗子!!
    www.sina.com.cn
    .cn是顶级域名
    .com.cn是二级域名
    .sina.com.cn是三级域名

  • 回归同源策略和Ajax
    Ajax也是URL来获取资源的,也会受到同源策略的限制,当不满足条件的时候,浏览器是不允许我们使用ajax来获取资源的。
    我们在使用AJAX的时候如果访问了一个不同源的资源的话,会直接报错。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • AJAX 原生js操作ajax 1.创建XMLHttpRequest对象 var xhr = new XMLHtt...
    碧玉含香阅读 3,192评论 0 7
  • 一、HTTP服务 1.1 C/S和B/S B/S架构:即Broswer、Server,将所有的服务都可以通过浏览器...
    福尔摩鸡阅读 686评论 0 4
  • 原文出处 http://blog.poetries.top/2016/11/26/Ajax-summary 关注公...
    程序员poetry阅读 6,687评论 3 110
  • Ajax的基本概念及使用 同步&异步 同步:必须等待前面的任务完成,才能继续后面的任务; 异步:不受当前主要任务的...
    magic_pill阅读 1,946评论 0 5
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139