码迷,mamicode.com
首页 > 其他好文 > 详细

【学习笔记】JaveScript

时间:2015-04-03 22:29:14      阅读:228      评论:0      收藏:0      [点我收藏+]

标签:

第一次看完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了,应该也差不多><

【学习笔记】JaveScript

标签:

原文地址:http://www.cnblogs.com/flytu/p/4391122.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!