Types in Javascript(jQuery)
String: 空字符串等于Boolean的false;
htmlString: 包括起始tag和结束tag的字符串,代表html代码;
Number:双精度64位,跟string一样属于immutable,基于c语言的运算符都适用于此值;0默认为false,!0为true;
Math函数,parseInt函数(各进制到int的转换);
转换为字符串,""+1+2==“12”,""+(1+3)==“4”......
NaN,非Number的对象会返回NaN,用isNaN函数判断;Number类型;
Infinity,1/0==infinity;Number类型;
Note:NaN==NaN is false,Infinity==Infinity is true;
Integer属于Number类型,必须为非浮点数;
Float属于Number类型,为浮点数;
Boolean: true or false;
Object: var x = {}; {}的类型为object,默认值false;
var y = {name: "Pete",age: 15};
使用dot访问对象的属性:y.name or y.age;
使用array索引访问,y[name],y[age]
迭代for(key in y){ //do sth with key, and access value using y[key]};
Note:使用其他library的时候,可能扩展了Object.prototype,so take care!如:jQuery.each(obj,function(key,value))){}
Note:javascript对象没有继承机制,a workaround是使用prototype满足继承关系:
var Employee = function(name, title) { this.name = name; this.title = title; this.greet = function() { if (this.canTalk) { console.log("Hi, I'm "+this.name+", the "+this.title); } } } var Customer = function(name) {this.name = name;} var Mime = function(name) {this.name = name;this.canTalk = false;} var Person = {
canTalk : true,
greet : function() { if (this.canTalk) {console.log("Hi, I'm "+this.name)}
} }
继承机制为prototype; Customer.prototype = Person; Employee.prototype = Person; Mime.prototype = Person; var bob = new Employee('Bob','Builder'); var joe = new Customer('Joe'); var rg = new Employee('Red Green','Handyman'); var mike = new Customer('Mike'); var mime = new Mime('Mime'); bob.greet(); joe.greet(); rg.greet(); mike.greet(); mime.greet();
Array: var x=[]; var y=[1,2,3];数组的类型为object,使用索引读写数组;无论空否,数组默认为true;
数组迭代使用y=a.length作为终止条件,只读一次属性,速度比使用a.length作为终止条件快;
for ( var i = 0, item; item = a[i]; i++ ) {// Do something with item}此时数组不能为空;
var x=[1,2,3]; jQuery.each(x,function(index,value){//do sth with index and value});
var x=[]; x.push(1); x[x.length]=2; x is [1,2];
support method: reverse, join, shift, etc.
Array<Type>在Jquery中表示方法需要的参数类型是数组,且元素类型是指定值;
PlainObject: jQuery.isPlainObject(object)判断对象是否由{}或new Object(){}创建;
Function: 命名函数和匿名函数;
Arguments
function log( x ) {console.log( typeof x, arguments.length );} log(); // "undefined", 0 log( 1 ); // "number", 1 log( "1", "2", "3" ); // "string", 3
Note:上面的log函数体中,arguments变量总是有效的,arguments变量有length,callee(调用者)等属性;
var awesome = function(){return arguments.callee;}
awesome()==awesome //true;
Context,Call,Apply
"this"引用当前context,默认引用window对象,在function中可以改变context;
Function.prototype.call() and Function.prototype.apply(); refer to here and here.
NOTE: call和apply的异同:1.无参数时两者无区别;2.函数带参数时候,call(this,argumentsList),而apply (this,argumentArray);
Scope: 变量的作用域;
Closures:
function create() { var counter = 0; return {
increment: function() {counter++;},
print:function() {console.log( counter );}
} } var c = create(); c.increment(); c.print(); The pattern allows you to create objects with methods that operate on data that isn't visible to the outside—the very basis of object-oriented programming.
Proxy Pattern
Callback:
Callback is a plain JavaScript function, or sometimes just an event;
$( "body" ).click(function( event ) { console.log( "clicked: " + event.target );
});
Some callbacks are required to return something, others make that return value optional. To prevent a form submission, a submit event handler can return false:
$( "#myform" ).submit(function() { return false; });
|
for instance, validation plugin accepts a selector to specify a dependency, whether an input is required or not:
emailrules:{required:"#email:filled"}
Events: blur,focus, load, resize, scroll, unload, beforeunload, click, dblclick, mousedown, mouseup, mousemove, mouseover, mouseout, mouseenter, mouseleave, change, select, submit, keydown, keypress,and keyup.
jQuery: jquery object is a collection of DOM elements, it behaves much like an array but not actually a Javascript Array;
you will use the jQuery() function to create a jQuery object. jQuery() can also be accessed by its familiar single-character alias of $(), unless you have called jQuery.noConflict() to disable this option. Many jQuery methods return the jQuery object itself, so that method calls can be chained:
$( "p" ).css( "color", "red" ).find( ".special" ).css( "color", "green" );
会对jQuery对象进行筛选,如find(),这些操作会返回一个经过筛选的新的jQuery对象;需要返回前一个jQuery对象则用.end(). 出的jQuery对象为empty,则最后的操作对DOM没有影响。
XMLHttpRequest: 有些AJAX返回XHR object,或者作为参数传递给success/error/complete hanlders,可以在其他操作中使用这个对象。 NOTE:Ajax只有在request使用此对象的情况下才返回该对象。 |
jqXHR: 从jquery1.5开始,$.ajax()返回jqXHR对象,which is a superset of the XMLHTTPRequest object.
Deferred Object(延迟对象): 使用自我管理的callback queues注册多个callback,按需调用。
Promise Object:此对象提供延迟对象的方法子集(then,done,fail,always,pipe,isResolved,isRejected),防止用户更改延迟对象。
Callbacks Object:使用方法$.Callbacks()来create或者返回Callbacks对象,此对象用途广泛,比较强大的功能是用来管理callback lists。
XML Object:一个由浏览器的XML DOM parser创建的文档对象,一般来自一个代表XML的字符串,XML文档与HTML语法不同,但jQuery的大多数遍历或操作都适用于此对象(XML文档)。
仅作个人学习只用,转载注明原文出处,引自:http://api.jquery.com/Types/
Types in Javascript(jQuery)的更多相关文章
- insertBefore方法(javascript与jQuery)
说到insertBefore()方法,其实javascript与jQuery中都有此方法,那么他们用法是否相同呢? 其实,还是有点区别的.反正我是爱搞混淆了,先做个小笔记吧! 1.insertBefo ...
- 初探JavaScript(一)——也谈元素节点、属性节点、文本节点
Javascript大行其道的时候,怎么能少了我来凑凑热闹^_^ 基本上自己对于js的知识储备很少,先前有用过JQuery实现一些简单功能,要论起JS的前世今生,来龙去脉,我就一小白.抱起一本< ...
- JavaScript(1)
JavaScript(1) 第一次见到JavaScript的时候,看到了熟悉的"Java",原来都是骗人的,李鬼不是李逵呀=.= 然而发现这个东西还是特别实用的,和Java比起来它 ...
- 前端开发面试题总结之——JAVASCRIPT(一)
___________________________________________________________________________________ 相关知识点 数据类型.运算.对象 ...
- 前端开发面试题总结之——JAVASCRIPT(三)
___________________________________________________________________________________ 相关知识点 数据类型.运算.对象 ...
- 前端开发面试题总结之——JAVASCRIPT(二)
___________________________________________________________________________________ 相关知识点 数据类型.运算.对象 ...
- Sping MVC不使用任何注解处理(jQuery)Ajax请求(基于XML配置)
1. Spring Spring框架是一个轻量级的解决方案,是一个潜在的一站式商店,用于构建企业就绪的应用程序.Spring框架是一个Java平台,为开发Java应用程序提供全面的基础架构支持.Spr ...
- Struts2处理(jQuery)Ajax请求
1. Ajax Ajax(Asynchronous JavaScript and XML,异步JavaScript和XML)时一种创建交互式网页应用的网页开发技术,它并不是一项新的技术,其产生 ...
- Servlet处理(jQuery)Ajax请求
1. jQuery jQuery是一个JavaScript函数库,极大的简化了JavaScript编程,很容易学习.jQuery是目前最流行的开源js框架,并且提供了大量的扩展. 2. Aja ...
随机推荐
- 如何查看Linux的CPU负载
哪些工具可以查看 CPU 负载? 可以使用 top 命令.uptime 命令,特别是 top 命令,功能强大,不仅仅可以用来查看 CPU 负载. CPU 负载怎么理解?是不是 CPU 利用率? 要区别 ...
- PAT_A1015#Reversible Primes
Source: PAT A1015 Reversible Primes (20 分) Description: A reversible prime in any number system is a ...
- swift-正则验证手机号码
// 手机号验证正则表达式 func validateMobile(phoneNum:String)-> Bool { // 手机号以 13 14 15 18 开头 八个 \d 数字字符 let ...
- [bzoj3507 Cqoi2014]通配符匹配 (hash+DP)
传送门 Solution 显然用哈希233 设\(f[i][j]\)表示第i个通配符和当前第j个字符是否匹配 考虑两种通配符的特性,直接转移即可 Code #include <cstdio> ...
- [jzoj 5776]【NOIP2008模拟】小x游世界树 (树形dp)
传送门 Description 小x得到了一个(不可靠的)小道消息,传说中的神岛阿瓦隆在格陵兰海的某处,据说那里埋藏着亚瑟王的宝藏,这引起了小x的好奇,但当他想前往阿瓦隆时发现那里只有圣诞节时才能到达 ...
- cent OS官网上下载老版本系统镜像的正确打开方式
当时的情况是这样的: 客户需要给服务器安装cent OS 7.3操作系统,我打开官网https://www.centos.org/,点击“GET CENTOS”——>“Minimal ISO”, ...
- 48.Query DSL
主要知识点 1.Query DSL的理解及基本语法 2.如何组合多个搜索条件 bool 一.Query DSL的理解 Query DSL的查询形式如下: GET /_search { &quo ...
- Top English interview Q&A part 2.
https://www.zhihu.com/question/19666878 1.how do you handle failure? I have always lived by the maxi ...
- 彻底禁用chrome请停用以开发者模式运行的扩展程序弹框
首先上图 怎么解决呢? 进入安装目录-->下图目录(一串数字的目录) 2. 找到chrome.dll 3.下载patch.exe 下载网址 https://itdocs.pipipan.co ...
- (20)Spring Boot Servlet【从零开始学Spring Boot】
Web开发使用 Controller 基本上可以完成大部分需求,但是我们还可能会用到 Servlet.Filter.Listener.Interceptor 等等. 当使用Spring-Boot时,嵌 ...