javascript、jquery、json、ajax 详解



1. JavaScript

JavaScript(简称js)是一种主要运行于浏览器中的弱类型的动态脚本语言,可以用来实现网页上的一

些高级功能,如数据验证处理、页面动态效果、定时任务、与用户交互、发送/接收服务器端数据等等。

动态语言指的是程序运行时可以改变结构,主要体现在:
① js中的变量在声明的时候不需要指定类型,其实际类型由程序运行中的赋值决定,在运行过程中变量

的类型也可以改变。注:这一点是动态语言的特征,并不是弱类型语言的特征,之前的回答有误。
② 函数可变。js允许在运行过程中使用eval动态执行字符串里的命令,也可以通过new Function等方

式由字符串动态构造函数,函数可以被创建、修改、删除,可以从已有函数构造出新函数,等等。
③ 对象的成员可变,可以动态添加、删除成员属性或成员方法。

弱类型指的是js中的变量在参与运算的时候可以根据实际需要动态转换类型。与之相对应的是强类型语

言——变量一般不允许自动转换类型(某些强类型语言的字符串连接操作除外),如果参与运算、调用

时不符合要求的类型,则会在编译阶段报错。

js是1995年由Netscape公司的Brendan Eich为自家的浏览器Netscape Navigator开发的,当时意图是

用于网页上的表单验证,即验证表单的各个输入项是否符合预定规则,在验证通过后才向服务器提交表

单内容,减少页面与服务器端不必要的频繁交互。

js的最初版本只用了10天就开发完成,当然不是完全从无到有,而是借鉴了其他一些语言的特性来开发

。如此仓促开发,js自然有一些先天不足,但同时也具备了基于弱类型动态语言的方便灵活、对象原型

继承、函数是一种特殊的对象等优秀特性,于是越来越得到广泛应用,而语言自身也在标准化组织的推

动下不断发展进步。

在浏览器发展的早期,Microsoft仿造JavaScript推出了相似的脚本语言JScript,在IE浏览器中使用

,Microsoft同时推出的还有VBScript。后来为了解决不同浏览器中脚本语言不兼容的问题,在ECMA(

欧洲计算机制造商协会)成立了标准化小组,由各厂商参与,共同制定JavaScript的语言规范,规范化

的这门语言被命名为ECMAScript。

js也可以在浏览器之外的其他场合使用,如服务器端的Node.js、java的Rhino、无界面浏览器

PhantomJS等。

2. jQuery

jQuery是js的一个工具库,由John Resig在2006年发布。
j代表JavaScript,query是“查询”的意思。也就是说,这个库的意图是基于JavaScript的查询。
查询的目标是什么?答案是DOM(文档对象模型)结构中的Node(节点)。一个网页就是一个html文档

,而网页上的所有内容都是节点,包括文档节点、元素节点、文本节点、注释节点、属性节点等等。而

jQuery的查询最主要针对的是元素节点,如段落(p)、锚点(a)、表格(table)等,只有少数方法

可以处理文本节点与注释节点。同时jQuery还可以用attr方法方便地对元素节点的属性进行读取/设置


在jQuery出现之前,在js程序中获取元素节点比较麻烦,例如获取id为elem1的节点:

document.getElementById('elem1')

或者是获取页面上的所有checkbox元素,首先需要获取input类型的元素:

document.getElementsByTagName('input')

然后对获得的元素列表进行for循环处理,逐个判断其类型是否为checkbox。
如果有更多元化的查询要求,则对应的js代码也会相当复杂。虽然有一些库可以解决这方面的需求,但

强大程度、易用性等方面都不太理想。
John Resig发现了一个盲点——css样式应用到页面上的元素时,是有一套规则的,即css选择器,浏览

器可以通过css选择器找到匹配的元素并将指定的样式应用到这些元素上。也就是说,通过css选择器可

以有效地进行元素查找定位,但它最初只被用于样式领域。于是,John Resig根据css选择器编写了

jQuery选择器,并对选择器的规则进行了扩充,从而让元素查找变得非常方便。例如,上面2个例子用

jQuery可以写为:

$('#elem1')



$(":checkbox")

同时,jQuery还有一个核心思想——链式操作,例如:

$('div.con')
    .height(100)
    .show();

这样的连续调用可以让代码书写更加简洁,也就是jQuery自己的口号:write less, do more。

此外,jQuery还提供了浏览器兼容、样式读写、事件绑定与执行、动画等特性,后来又加入了ajax、

promise等,再加上方便的插件编写机制,对整个js的生态圈产生了重大的影响,可以说是js历史上影

响力最大的一个库。其中选择器引擎后来被单独剥离出来成为sizzle,供其他的js库调用。这部分的工

作还影响了官方,在jQuery成功之后,浏览器才有了querySelector与querySelectorAll方法。时至今

日,虽然有了querySelector与querySelectorAll,但jQuery的选择器仍然有少部分特性是前2者所无

法替代的。

3. ajax

ajax全称Asynchronous JavaScript and XML(异步的JavaScript与XML),是网页无需刷新页面、使

用js与服务器进行交互的一种技术。

有时候会有这样一种需求:只希望更改页面上的一个区域。然而在从前的技术框架内只能刷新整个页面

,带来的后果是:①需要重新传输整个页面,服务器端与客户端的流量消耗都会比较大;②如果是动态

页,服务器端需要重新生成整个页面,即使是那些客户原本不想要刷新的区域,增大了服务器的负担。

Google的Jesse James Garrett在2005年初发表了一篇文章,提供了解决这种需求的技术方案,也就是

ajax。实际上这是一种实践先行的技术,该方案的技术依赖之一XMLHTTP在1998年就已经被Microsoft开

发出来了,而Google在若干年后使用这项技术开发Google Maps等产品之后,才发表了相应的文章并对

其进行了命名。

ajax的基本流程可以概括为:页面上js脚本实例化一个XMLHttpRequest对象,设置好服务器端的url、

必要的查询参数、回调函数之后,向服务器发出请求,服务器在处理请求之后将处理结果返回给页面,

触发事先绑定的回调函数。这样,页面脚本如果想要改变一个区域的内容,只需要通过ajax向服务器获

取与该区域有关的少量数据,在回调函数中将该区域的内容替换掉即可,不需要刷新整个页面。

XMLHttpRequest在发送请求的时候,有两种方式:同步与异步。同步方式是请求发出后,一直到收到服

务器返回的数据为止,浏览器进程被阻塞,页面上什么事也做不了。而异步方式则不会阻塞浏览器进程

,在服务端返回数据并触发回调函数之前,用户依然可以在该页面上进行其他操作。ajax的核心是异步

方式,而同步方式只有在极其特殊的情况下才会被用到。

XMLHttpRequest在早期IE浏览器里是使用ActiveX来实现的,并不是浏览器自身的对象。后来其他各家

浏览器也都实现了XMLHttpRequest对象,而高版本IE也把XMLHttpRequest改为了浏览器的内建对象。

4. JSON

JSON全称JavaScript Object Notation(js对象标记法),由Douglas Crockford在2002年发现并制

定了标准。从名称上就可以看出来,JSON是基于JavaScript的,是JavaScript的一个子集。JSON是用

JavaScript语法来表示数据的一种轻量级语言。

虽然Douglas在2002年就注册了http://json.org,并且为各种语言编写了解析与构造JSON数据的库,

但在最开始的几年JSON一直没有得到足够的重视。情况一直延续到ajax的出现。

从ajax的命名中我们就可以看到,数据交换是通过XML格式进行的。在ajax刚出现的时候,绝大多数应

用都是采用XML格式,也有少数使用纯文本的。但是XML格式有一个缺点,就是文档构造复杂,需要传输

比较多的字节数。在这种情况下,JSON的轻便性逐渐得到重视,后来替代XML成为ajax最主要的数据传

输格式。可以举个简单的例子感受一下二者的区别:



 

    Article Title1
    content1
 

 

    Article Title2
    content2
 




{
  "article" : [
    {
      "title": "Article Title1",
      "content": "content1"
    },
    {
      "title": "Article Title2",
      "content": "content2"
    }
  ]
}


XML规范实际上是比较复杂的,单纯作为数据传输来说它太重了。在ajax领域中JSON取代XML的过程,是

一个很好的“用脚投票”的范例。

而JSON的影响力在此后还继续扩大,有些软件将其作为配置文件的格式,有些编程语言也吸纳了JSON的

优点。例如c#,在高版本里可以这样写:

Dictionary dict = new Dictionary{
    {1, "a"},
    {2, "b"}
};


但是如果c# 2.0这样写,可是会报错的。在2.0里只能写成下面这种形式:

Dictionary dict = new Dictionary();
dict.Add(1, "a");
dict.Add(2, "b");

等价于

Dictionary dict = new Dictionary();
dict[1] = "a";
dict[2] = "b";


比较一下两种写法的区别,不仅有便捷性的差距,而且前一种写法可以在声明变量的同时为变量赋值,

后一种写法则不行,这会影响到类属性的初始化操作:在c# 2.0中,只能把针对Dictionary之类复杂对

象的初始化代码写在函数里,而不能直接写在类属性的声明处。

感觉上是c#受了JSON(或者说js)的影响。但此处是我个人的感觉,如有错误请指出。

回到js自身,对于对象构造有两种方法:基于对象的完整写法,字面量表示法。前者如:

var obj = new Object();
obj.title = "title1";
obj.content = "content1";

而与之对应的字面量表示法则写为:

var obj = {
    title: "title1",
    content: "content1"
};


可以明显看出字面量表示法要简洁得多。而JSON基本就是字面量表示法的一个子集,除了强制要求键与

字符串类型的值必须用双引号包起之外,它剔除了undefined、function等类型,也不包括浏览器内置

对象类型(如Date、RegExp等),是基于文本的、比较纯粹的数据表示方法。所以说,Douglas是“发

现”了JSON,而不是“发明”。标准的JSON不包含注释,但后来因为实际需求而出现了能够处理注释的

JSON库。

5. Node.js

Node.js是Ryan Dahl在2009年发布的、主要用于服务器端的Javascript运行环境,也可以用于个人电

脑。
Ryan Dahl此前一直在寻找一种事件驱动型的、异步的服务器端框架,实际上,js并不是他的首选。他

是在尝试了几种语言之后,才发现js的函数回调与单线程特性正好契合他的要求,于是Node.js应运而

生。
js的异步回调在ajax的部分已经提过:在调用异步方法的时候,可以将后续的处理函数作为参数传入,

在调用相应的异步接口之后,程序会将线程的控制权让出,允许其他代码执行;在接口返回处理结果后

,再执行后续处理函数(即回调函数)。实际上,因为js是单线程语言,回调函数并不是立刻被执行的

,而是会被送入任务队列,在线程空闲、并且队列前方没有其他任务的情况下,才会被执行。

用户在向服务器提交请求的时候,如果处理比较费时,传统的服务器端框架会导致处理线程被阻塞。而

js的特性使得异步任务在执行的时候让出线程的控制权,在处理完成后再进行正确的回调,从而能够获

得比较好的高并发处理能力。
js本身是一门严格的单线程语言,而Node.js为了充分发挥服务器的处理能力,在运行环境级别上增加

了对于多线程的支持(child process)。但Node.js的多线程与常规的多线程有很大区别——常规语言

的多线程允许多个线程共享数据,或者调用其他线程暴露出来的公开方法,而Node.js的多线程只能用

消息机制进行通讯。这样,Node.js就规避了常规多线程的数据同步、线程锁(线程同步/互斥)等复杂

问题,规避了一些潜在风险。

Node.js使用的V8引擎实际上就是Google的Chrome浏览器使用的Javascript引擎(因为V8引擎是开源的

),并进行了模块扩展。例如遵循CommonJS标准的模块定义,适合服务器需求的多线程、集群、

HTTP/HTTPS,文件系统,等等。Node.js中的很多方法都同时提供了异步版本与同步版本,从函数的命

名上可以简单区分。
得益于其模块特性,Node.js的模块扩展变得相当方便,用于Node.js包管理的npm得到了广泛的使用,

但也曾经引起“是否过度使用依赖包”的争论。

Node.js不仅可用于服务器端,因为其安装完成之后可以用命令行方式方便地调用,因此在个人电脑中

也逐渐得到广泛应用。例如为代码编辑器提供插件、用于桌面的Node.js App等。另外还有一个重要的

应用领域就是前端自动化,包括代码的预编译/转换(如使用Babel将ECMAScript 6的代码转换为低版本

的es代码,将sass/less的样式表文件编译为传统的css文件)、语法检查、代码文件或图像文件的合并

、代码的混淆/压缩、自动分发、自动测试等,还可以监视开发文件夹,在内容改变时自动执行上述操作

,并自动刷新浏览器页面。这样使得前端领域的开发方式得到了大大进化。

js虽然因为有着一些先天不足而被人诟病,但这些年来却越发展越壮大。这不仅仅是因为依托于浏览器

这个宿主环境,更是因为其自身具备的一些优秀特性,Node.js的出现与发展就是一个很好的例证。

总结

ajax与Node.js都使用了js的异步回调特性。
jQuery的出现解决了那个各方面标准尚未统一的混乱时代的许多问题,让js的应用更加广泛,并为未来

某些标准的制定指明了方向。
JSON从js中脱胎而出,作为一种简洁、扩展性好的轻量级数据表示方法,在很多领域得到了广泛使用。
Node.js在服务器端与开发流程中都越来越得到重视。
由于Node.js不包含BOM与DOM,因此jQuery不能直接在Node.js上使用,但可以借助jsdom、cheerio之

类的库,在构造出虚拟的dom结构后再使用。查看github上的jQuery开发包,可以看到它使用了Node.js

上的grunt来进行自动化构建、测试的工作。
以上几项技术的共同进步,配合浏览器的进步,此外还有硬件条件的发展,让复杂的页面应用越来越多

,许多以前在服务器端进行的工作可以转到客户的浏览器中进行,顺应了分布式处理的潮流。


1. js设计之初并不是用来弹窗或者改变页面上内容,这些功能是随着浏览器的发展才出现的。实际上

js语言自身并不能实现这样的需求。

完整的JavaScript包括ECMAScript、BOM(浏览器对象模型,如window、location等对象)、DOM。其

中BOM和DOM虽然是js的组成部分,但js只规定了这两者的接口规范,即浏览器返回这两类对象时,可以

用js的方式来处理(点号或者方括号来操作对象成员,可以读取或修改属性等)。也就是说,js脚本通

过浏览器提供的接口去操作BOM和DOM,js在其中主要进行流程控制。没有这些接口的支持,js自身是无

法完成一些功能的。而早期各家浏览器对于接口实现的不同,也带来了比较严重的兼容性问题。

从js的标准化工作也能看出之间的不同。ECMAScript是由ECMA来进行标准化工作,而BOM和DOM则是由

W3C(World Wide Web Consortium)来进行标准化的。

2. jQuery设计的第一要素是对于节点的查询。解决兼容性问题也是jQuery设计的重点,但不是第一位

的。当时在尝试解决兼容性问题的js库有好几个,jQuery在这方面并不唯一。而jQuery选择器才是

jQuery划时代的特性,从早已存在的事物(css选择器)中发现了价值,并将其修改扩充、发扬光大。

不可否认,jQuery的流行很大程度上要归功于解决兼容性问题,但作为名称中包含的“query”连提都

不提,这答案有点偏了。

3. ajax创建之初是用于处理Gmail、Google Maps这样的复杂页面应用,表单提交方式的改变只是ajax

技术发展的一个副产品而已。

并且表单提交的问题并不仅仅在于填错项目,实际面临的问题要复杂得多,包括用户的网络掉线、服务

器端因为请求过多而暂时无法响应等不可抗因素。在传统模式下,提交表单是前往一个新的动态页,如

果出现了错误,运气好的时候点浏览器的“后退”按钮还可以返回表单填写界面,刚才写的东西都还在

;运气不好的时候,只会看见一个空白的表单。当时在一些论坛里,总能看到“辛辛苦苦码的字一提交

就全没了”的哭诉。

4. 对于JSON的用途描述有错。原答案中提到提交内容简单的时候,用字符串发送,后来改为XML与JSON

。实际上,JSON用于客户端(包括浏览器)与服务端通讯的时候,主要指的是服务器端返回处理结果时

送回给客户端的数据格式是JSON。而客户端提交给服务器端的数据大多数并不是XML或JSON格式的。
客户端向服务器端提交数据的时候,使用GET或POST方法,其数据一般是简单的“键/值对”表示,例如

常见的GET方法在url中构造的参数:

?page=1&pagesize=20

POST方法在提交一般类型的表单时,与GET方法在数据组织形式上基本相近(除非是用multipart类型的

表单发送文件数据),但http数据包格式、浏览器历史记录、以及服务器端接收处理有所区别,这属于

http协议的内容,此处不展开。
因此,客户端向服务器端提交数据的时候,主要是采用字符串拼接的方式按上述例子构造,一般不会使

用XML或者JSON格式,特别是在ajax出现的早期。(近年来随着页面应用越来越复杂,用JSON格式向服

务器端传递数据的情况也逐渐增加)
而服务器端返回给客户端的数据格式,一开始的主流就是XML,不存在以字符串为主然后过渡到XML的过

程。
另外,XMLHTTP还可以用来进行服务器间通讯,早期发送与接收数据的主流格式都是XML,但是这与ajax

不是一回事。
—————————————————————————————————————————————

——————

有一天,你们人类不满足网页只是一些文字和图片的展示,希望页面上可以有更多功能。比如点击一个

按钮,弹一个窗口或者改变页面上某些内容。

为了实现这种功能,就创造了一门脚本语言,逐步升级演化成了 JavaScript 这门语言。

JavaScript 为页面提供更多功能,是页面交互功能的基础语言。此外它的语言规范和引擎还被用于其

他领域,比如 Node 等。

人类为了让自己页面功能更加丰富,使用了大量的 JavaScript,并且写了非常多的代码。这时候发现

不同浏览器对 JavaScript 的支持程度非常不统一,而且原生 JavaScript 实现某些看起来很简单的功

能都很麻烦。于是 jQuery 就把这些兼容性问题统一,并封装了大量的 API,可以让你非常简单就实现

很多功能。

jQuery 屏蔽了浏览器之间的兼容性问题,针对常用功能封装了大量的 API,并支持插件机制,让你写

JS 的效率很高,质量很好。

简单的页面上的交互再次不满足人类的需求,比如一个资料填写表单,需要填写一个名称,这个名称还

必须不能跟之前的重复。校验这个名称不能重复,就需要把数据提交上去,与服务器端数据交互的方法

就是 form 提交表单。这时候需要用户填完所有的表单,点击『确定』之后提交校验。如果此时名称被

占用就悲剧了。

解决这个问题的方案关键点在数据交互上面。最好的解决方案应该是输入完名字之后,就自动去吧数据

发给后端,然后拿到结果并提示给用户,而不是统一提交。于是人类就想出了一套新的数据交互方案,

即无刷新的异步请求,名字叫 Ajax。通过 Ajax 可以通过 JS 与后端接口进行数据交互,而不会影响

当前页面。当接口返回『被占用』的时候,JS 在页面上给个提示就可以很好的实现了。

Ajax 技术提供了一种新的前后端数据交互方式,不需要刷新页面,而且不阻塞页面执行流程,异步的

去请求去获取、交互数据。

一开始只是通过 Ajax 异步发一个请求,数据就是一个简单的用户名称,所以直接按照字符串发过去就

好了。后来需要 Ajax 发送的数据越来越多,比如一整张表单。这时候就需要有一套规则来描述更复杂

的数据,一开始估计就是用一些字符分割拼起来,再后来人类用 xml 来描述,发现解析还是挺麻烦的

,于是就基于 JavaScript 的数据类型创造了 JSON 这种数据描述格式,很简单的就可以描述很复杂的

数据。同时独立于语言,这样就可以在多种语言内使用。

JSON 用来描述前后端数据交互的内容格式,有了 JSON 这样的一套统一的描述规则,前后端解析数据

的成本变低,使用非常简单。JSON 属于 JavaScript 的一个子集。
这就是上面几个关键词的关系和用途。
—————————————————————————————————————————————

——————

觉得html和css做出的静态网页太安静单调,于是有了javaScript,从此网页动起来了,觉得

javascript的语法好繁琐,于是封装了一套库,起名叫jquery,简洁的语法深受大家的喜爱,觉得点个

赞整个页面都要刷新,好慢,又费流量,于是有了ajax,实现酷炫的局部刷新,用户体验更好,交互性

更强,

觉得javascript中的对象数组啥的传来传去的不方便,于是统统按照键值对的格式转换成字符串,这种

格式叫JSON,后多用于后端传递数据,

1、javascript是一门语言,早期运行于前端,负责网页的动画及前后台的交互,现已进化成前后台端

通吃,

2、jquery是为了简化javascript语法而形成的库,其实就是对javascript的封装,形成更简洁的语法



3、ajax是一种技术,或者说是一种思想,用来实现异步刷新,用javascript和jquery都可以实现该技

术。

4、JSON是一种简单的数据交换格式,简单来说就是javascript种的对象和数组,按照一定的语法采用

键值对的格式将数组和对象转换成字符串,然后进行传递。


javascript是一种语言,面向web编程,是前端工程必须要掌握的技能之一,

javascript核心api设计简单,但是由于浏览器之间的严重不兼容,导致客户端的api过于复杂,使用

javascript的框架或工具类库,能够简化通用操作,隐藏浏览器之间的差异,jquery就是其中一个类库



ajax全称是Asynchronous javascript and xml,可以帮助我们于服务器交换数据,在不重新加载整个

网页的情况下,更新部分网页,

JSON是一种轻量级的数据交换格式,是javascript的一个子集。

—————————————————————————————————————————————

————————————————————————————————

javascript和jquery有点关系,js是一种脚本语言,主要用于客户端,主要用于实现一些网页效果,

jquery是js的一个库, 可以认为是对js的补充,提供了很多方便易用的方法,兼容性也好很多。
ajax   意思是异步javascript和xml。是一种创建交互式网页的技术,简单点说就是不通过后台在网站

前台进行数据库才做
JSON(javascript Object Notation)是一种轻量级的数据交换格式,有点像xml,用于在不同平台减

缓数据,不过json
可以一直接传送对象,方便不少。



javascript、jquery、json、ajax 详解_第1张图片
HTML 是用来展示界面的
javascript 用来操作界面的
jquery 是封装了下javascript,方便开发人员更好地使用javasciprt的
ajax 是一种传输 技术,
json 是一种规定的格式,类似如 xml


你可能感兴趣的:(javascript、jquery、json、ajax 详解)