由于JS表达式偏啰嗦,于是最近便开始采用Coffeescript来减轻负担.举个栗子,当我想取屋子里的第一条dog时,首先要判断house对象是否存在,然后再判断house.dogs是否存在,最后取house.dogs[0].在JS需要这么写 var dog = (typeof house !== 'undefined' && house !== null) && house.dogs && house.dogs[0] 在Coffee中,我只需要这么写: d…
原来void是将其后的字面量当元表达式执行,并永远返回undefined.同时undefined不是关键词.. 由于JS表达式偏啰嗦,于是最近便开始采用Coffeescript来减轻负担.举个栗子,当我想取屋子里的第一条dog时,首先要判断house对象是否存在,然后再判断house.dogs是否存在,最后取house.dogs[0].在JS需要这么写 var dog = (typeof house !== 'undefined && house !== null) &&…
new 操作符 在有上面的基础概念的介绍之后,在加上new操作符,我们就能完成传统面向对象的class + new的方式创建对象,在Javascript中,我们将这类方式成为Pseudoclassical. 基于上面的例子,我们执行如下代码 var obj = new Base(); 这样代码的结果是什么,我们在Javascript引擎中看到的对象模型是: new操作符具体干了什么呢?其实很简单,就干了三件事情. var obj = {}; obj.__proto__ = Base.proto…
javascript中递增递减属于一元操作符,所谓一元操作符,即只能操作一个值的操作符. 递增和递减操作符各有两个版本:前置型和后置型.顾名思义,前置型应该位于要操作的变量之前,而后置型应该位于要操作的变量之后. 01.前置型操作符使用: var age=29; ++age; 等同于 var age=29; age=age+1; 执行前置递增和递减操作时,变量的值都是在语句被求值以前改变的. var num1=2; var num2=20; var num3=--num1+num2; //等于2…
有这么一种常见的语句: var a = a || 4; 那赋值语句中的"&&"操作符和"||"操作符是什么意思?如何知道这两个逻辑操作符两旁的数据哪个会被赋值到等号左边的变量里面?其实,会被赋值到等号左边的变量里面的一定是起决定性因素的那个变量.其实这就是if...else的变种,要么a=a,要么a=4.虽然没那么直接,不过也省了不少代码. 什么是起决定性因素的变量? 我们知道,两个bool型变量a和b进行与操作,只有a和b的值都为true时,返回结…