《JavaScript高级程序设计》笔记

  1. ECMAScript的5中基本数据类型:Undefined、Null、Boolean、Number、String、Object,ECMAScript不支持任何创建自定义类型的机制,因为它的数据类型具有动态性,没有再定义其它类型的必要了。

  2. var操作符定义的变量将成为定义该变量作用域的局部变量,超出作用域该变量就会被摧毁。

function test() {
  var message = 'hi';
}
test();
alert(message); // 错误!

但是如果省略var操作符,就会定义一个全局变量:

function test() {
  message = 'hi';
}
test();
alert(message); // hi
  1. EMCAScript的变量时松散型的,可以表示任何类型,每个变量只是用于保存值的占位符而已。

  2. typeof操作符可以返回一个变量的类型,返回值是一个字符串。

  3. 从技术的角度看,函数在EMCAScript中是对象,不是一种数据类型。但函数也有一些特殊的属性,因此用typeof来区分函数和对象是有必要的。

  4. 其它数据类型的值可以转换为Boolean型,即调用Boolean()函数,转换规则为:

数据类型 转换为true 转换为false
String 任何非空字符串 空字符串("")
Number 任何非零数字 0和NaN
Object 任何对象 null
Undefined undefined

下边的代码可以弹窗:

var message = 'hello';
if(message) {
  alert("ok");
}
  1. Number类型表示8进制时,第一个数字必须是0:
var octalNum = 070; // 八进制的56

16进制的数字则必须以0x开头。

  1. NaN与任何值都不相等,包括NaN本身。

  2. isFinite()函数判断一个数值是否处于-InfinityInfinity之间。isNanN()函数判断传入的参数是否“不是数值”,这个参数可以是任何类型,如果能转换成数值,可以返回false,比如传入“10”,“true”都会返回false,“blue”则会返回true。

  3. 可以使用Number()、parseInt()、parseFloat()来将参数转换为数值,Number()函数规则比较复杂,一般用parseInt()或者parseFloat()。

  4. 可以用对象的toString()方法和toString()函数来将一个值转换为字符串,前者不能用于null和undefined,后者可以。

  5. ECMAScript不存在块级作用域,在循环内部定义的变量也可以在外部引用。例如:

var count = 10;
for(var i = 0; i < count; i++) {
  alert(i);
}
alert(i); // 10
  1. 可以使用for-in语句来枚举对象的属性,例如:
for(var propName in window) {
  document.write(propName);
}

这里使用了for-in循环枚举了BOM中window对象的所有属性。

  1. break和continue可以结合label语句来跳转到自定义的地方。

  2. with语句可以将代码的作用域设置到一个特定对象中。比如以下代码:

var qs = location.search.substring(1);
var hostName = location.hostname;
var url = location.href;

上边的代码都包含locaiton对象,使用with语句可以写成:

with(location) {
  var qs = search.substring(1);
  var hostName = hostname;
  var url = href;
}

在with代码块中,每个变量被认为是局部变量,如果在局部环境中找不到变量的定义,则会寻找location对象中是否有该属性。

不过在严格模式下,不允许使用with,否则会被视为语法错误。

使用太多with语句会导致性能下降,尽量不要使用。

  1. ECMAScript的switch可以用于字符串,case分支可以求值表达式。例如:
var num = 25;
switch(true) {
  case num < 0: 
    alert("Less than 0.");
    break;
  case num >=0 && num <= 10:
    alert("Between 0 and 10.");
    break;
  default:
    alert("More than 10.");
}

switch语句比较时,采用的是全等操作符("==="),因此不会发生类型转换,比如"10"不会等于10。

  1. ECMAScript使用function来声明一个函数,语法是:
function functionName(arg0, arg1, ..., argN) {
  statements
}

例如:

function sayHi(name, greeting) {
    console.log('Hi ' + name + ', ' + greeting);
}

sayHi("Bob", "how are you?"); // Hi Bob, how are you?
  1. ECMAScript的函数参数只是用来提供便利,不是必须的,解析器不会校验参数的个数。假如定义的函数有两个参数,那调用的时候可以只传一个参数、三个参数或者什么都不传,这都是合法的。其实参数是用一个数组来表示的,在函数体中可以通过arguments对象来访问这个数组,通过arguments.length来获取数组的长度,但请注意,arguments并不是Array的实例。例如:
function sayHi() {
    console.log(arguments.length);
    for(var i = 0; i < arguments.length; i++) {
        console.log(arguments[i] + " ");
    }
}
sayHi("1", 3, "cai"); // 3 1 3 cai
  1. ECMAScript中所有参数传递都是值,不可能通过引用传递参数。

  2. 函数声明与函数表达式的区别,见以下代码:

function functions(flag) {
    if (flag) {
      function getValue() { return 'a'; }
    } else {
      function getValue() { return 'b'; }
    }

    return getValue();
}

上边的代码中,在两个逻辑分支里面各有一个函数声明,但是对于函数声明,解析器会率先读取并且让其在执行任何代码前可用,意思就是别的代码还没运行呢,两个getValue声明已经被读取,所以总是执行最新的那个。而函数表达式,当解析器执行到它所在的代码行时,才会真正被解释执行,所以两个逻辑分支可以分别执行,如下:

function functions(flag) {
   var getvalue=null;
    if (flag) {
      getValue = function() { return 'a'; }
    } else {
      getValue = function() { return 'b'; }
    }

    return getValue();
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351