您的位置:首页 > 其它

【学习笔记】JaveScript

2015-04-03 22:02 176 查看
第一次看完js感觉so easy直接打开jQuery源码想一步到位结果SB了。本来想写个总结,但是看了n遍后感觉还是有很多地方么完全懂!不能一直卡在JS了赶紧把这篇补上,以后一边用一边理解了!

一、重要知识点:

1)5个原始类型:null、undefined、number、string、boolean;undeclare also be undefined

2)引用类型:引用(指针),一切皆对象(伪对象),超类Object;

3)布尔装换:Boolean(obj) 等价 !!obj;&&、||判断时转boolean返回值不转换;

4)复合运算符的优先级和'='一样;

写不下去了,发现全都是重点要抄过来就没意思了,再跟新><

二、一些小细节慢慢添加:

1)创建数组

var arr = [];//new Array()和Array()都返回object;new Numberf()返回object,Number()返回number;

2)创建对象

var obj = obj||{};

属性访问:

obj.attribute;

obj['attribute'];

方法调用:

obj.funName();

obj['funName']();

3)函数

(function funName(){code...})();//立即执行

几个容易搞混需要注意的地方:

1)null、undefined、NaN参加各种运算时的情况

2)对象原型构造,w3school上推荐的混合方式/动态原型似乎都不是最好的;

3)继承,同上。原型链不可以多重继承。w3cschool上面貌似没有提到Object.create()方法;

4)Array、String、Function一堆的方法不熟;

5)诸如 (function(){code...})()这样高大上的写法貌似还有很多,需要自己去淘;

6)RegExp 不知道智商足不足以攻克>.<

7)关于对象和继承,下面两个图说明一切,慢慢感悟:





from:http://www.cnblogs.com/renlong0602/p/4387588.html

基于Object.create()的继承:

function extend(subPro,superPro){
// var obj = obj||{};
// obj.__proto__ = superPro.prototype;//dangerous
// subPro = obj;
// subPro.prototype.constroctor = subPro;

subPro.prototype = Object().create(superPro.prototype);
subPro.prototype.constroctor = subPro;
}


对new和prototype的理解是关键,w3school居然一点都没提__proto__这货,是怕菜鸟乱动惹祸么:)

this暂时别去深究了,就当OC的self了,应该也差不多><
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: