1.JS中的是是非非
JS是一门计算机编程语言,是一门动态语言也称为脚本语言,是解析型编程语言。为何是脚本?由于他自己不能执行,就是没有main函数或主程序的入口,必须被他的宿主环境,也就是解析环境解析执行他。为是什么是解析型?由于JS不会进行编程,连接,汇编等一系统的过程生成某个文件,再执行,他就是以字符串形式加载执行..
2.JS中的真真假假
空,null,undefined,false,0,””,'',NaN都为假,其余都为真
3.函数,类,对象,构造器有什么区别?
答:在js中函数,类,对象,构造器能够说是没有任何区别的,咱们能够说函数既为对象,对象既为类,类既为构造器。但通常状况下,咱们称对象为那个类的实例,这是为了减小混乱。
复制代码 代码以下:
function Person(){
}
var person = new Person();
//Person咱们能够称为函数,类,对象,构造器(不带参数)
//person称为对象的引用 算法
4.懂this关键字,你懂JS五分之一.
this永远指向调用该方法(函数)的那个对象.(必背)
首先要知道this是什么?
this就是js中的一个对象。是一个对象,不是一个函数,此是的对象你能够看做是一个对象的引用,引用谁?引用调用方法的那个对象.
this这个对象存在哪里?存在JS代码中,通常存在于函数之中。若是你把this放到<script>标签中,你能够试下window==this,打印什么?为何?
剖析this关键字
复制代码 代码以下:
function ready(){
alert(this==window);
}
ready(); 编程
此时打什么?true,为何?
复制代码 代码以下:
function Person(){
this.name='张三';
alert(this==window);
}
new Person(); 数组
此时打印什么?false,为何?
把代码加长点.加一个var perso=
var person = new Person();
全世界的人都知道person引用了new Person产生的那个对象。new Person建立的是一个JS实例对象,咱们就能够绑定属性和方法.
看下面这段代码
复制代码 代码以下:
fn=function(){
}
fn.ready=function(){
alert(this== fn);
} 闭包
当调用fn.ready()的时候打印什么?true ,为何?
十分奇怪,this如今等于一个函数了..为何?
5.JS中静态方法和属性将助你一臂之力.
什么是静态.顾名思意:就是不动了,JS中不动的方法是什么?就是不须要建立实例,直接能够经过类名调用方法,哪里都没有动。方法就调用了。不须要任何额外的代码。这只是片面之言。所谓静态:就是属于类的属于类自己的特征.
Js中类既为对象,何不能直接绑定属性和方法。固然能够.
复制代码 代码以下:
fn=function(){
}
fn.name='张三';
fn.getName=function(){
return fn.name;
} app
这也行,但为何还要new 的过程,全都这样绑定不就能够了吗?思考
6.prototype和constructor的在JS框架中的影响
prototype为原型,是一个对象。,。
constructor为构造器,是一个函数
到如今为止,你要分清楚,何时的对象为对象,何时的对象是一个函数.也难为JS解析器,能解析运行如此灵活的代码。
prototype能够说他是一个类的静态的属性,他指向这个对象的实例。换句话说prototype是一个对象。prototype指向的对象和咱们new的对象有何区别?创建了一种等价桥梁关系,但不是同一个。当咱们在函数prototype上绑定属性的时候,那么属性和值就绑定到了prototype对象上,并无正真的绑定到那个对象上去。当须要访问那个对象上的这个属性的时候,JS解析器,首先会去从对象自己上去找这个属性,而后再到原型对象上找。
复制代码 代码以下:
function Person(){
}
var person = new Person();
person.name=”张三”;
Person.prototype.name=”李四”;
alert(person.name);
delete person.name;
alert(person.name); 框架
constructor指向一个对象的构造器。(什么是构造器?本身去复习。),由此能够看出他是一个对象级别的属性。也就是要使用constructor这个属性,必须须要一个对象。
那么prototype是一个对象有没有constructor属性?固然有,既然constructor是指构造器,那有没有一个prototype属性?固然有,以此类推,下面这两段代码是正确的.
constructor.prototype.constructor.prototype.constructor……
prototype.constructor.prototype.constructor.prototype……
其实我也不知道到底能够连多长?感兴趣能够试一下。顺便告诉你用递归算法。
在众多的JS代码中,当咱们已知一个对象,要求他的构造器,或者已知一个构造器,求他的对象。应入门了。
7.==和===将判断进行到底.
==和===神像形不象.不要去考虑,一眼就看出是作断判是否相等。
有木有区别?
==判断变量是否相等。
===判断变量的值相等。
以此类推:====用来干吗的??用来报错的.你懂的.这里只想告诉你,只有==和===
JS中变量是弱类型的,都懂。
复制代码 代码以下:
var a=3;
var b=”3”;
alert(a==b);
JS中变量的值是强类型的。你懂的.
var a =3;
var b =”3”;
alert(a===b); 编程语言
都是var 类型的变量,但他们的值不同,一个是整形,一个是字符串型.
var类型和var类型相比,固然是true,整形和字符串型比,固然是false.
==用来比较他们值是否同样。不会是计较值的类型,只要他们的变量是var类型就能够了。固然是这废话,难不成,你不还能声明第二种变量类型的变量?.
===用来比较,会去判断他们的值是否为同一类型。若是不是,没有的比较。JS中变量的值是强类型的,有整形,字符串,数字,布尔等.
8.typeof和instanceof完成了判断未成的使命
typeof用来判断基本数据类型
instanceof 用来判断对象类型是否为某一个类型号
9.5种继承让你如虎添翼.
i.对象冒充
ii.apply
iii.call
iv.prototype
v.for循环方式
用法:永远只须记住,JS中的继承只是属性和方法的拷贝.
10.DOM模型结构改变你的思想
DOM是一种思想,一种将数据以树状结构数据的思想。学习DOM只须要掌握任何一个节点都有一个父节点和0到多个子节点.任何一个节点都有一个页面上的标签表现形式和一个内存对应着一个标签对象.页面只是展现数据的地方,内存中才是DOM对象数据保存地方。任何一个DOM对象只能有一个父节点对象。父子关系能够随时改变。
必须:
获取对象:查
对象操做:增,修,删
内容操做:innerHTML,innerText等
事件操做:mouse,key
样式操做:id,tag,class
属性操做:attribute
11.回调函数减小编写代码
什么是回调函数?
在JS中函数名是用来标识一个函数的。既咱们能够传递给某个函数一个函数名(函数名柄),而后由那个函数来自动调用咱们的函数完成相关的处理。
调用者与被调用者分开,咱们不须要关心调用者,和被调用者。回调可用于通知机制,事件。
12.函数和arguments
函数名就是函数的句柄,指针,函数名是惟一的,这也成就了JS中没有函数重载。只有函数覆盖。函数名才是惟一标识函数的。
永远需牢访,JS中的函数调用就是在函数名后面加对括号()
函数调用参数无关紧要,不管什么状况下,参数都会保存在函数体中的arguments对象中,你能够直接使用他,他是一个对象,参数是以数组形式存放。
13.闭包(匿名函数)为开发开辟了捷径
闭包是函数内调用函数外的参数,通常也可称为匿名函数,但二者有所不一样。
闭包的价值在于能够做为函数对象或者匿名函数,对于类型系统而言这就意味着不只要表示数据还要表示代码。支持闭包的多数语言都将函数做为第一级对象,就是说这些函数能够存储到变量中、做为参数传递给其余函数,最重要的是可以被函数动态地建立和返回.
匿名函数减小了变量名称的冲突,为没有权限做用域的JS提供了权限做用域。当咱们须要提供一个接口,但又不想让这个接口对象为全局变量就须要用匿名函数:
(function(){
局部代码,外部永远没法访问,除非你提供一个入口
})(); 函数