关闭

你不知道的 js 保留字

时间: 2018-08-27阅读: 1219标签: js知识

一、保留字的分类:

先是笼统的说一下有什么保留字,保留字的话根据犀牛书的划分,可有分为以下几类:

① :基础保留字: 这类保留字是最常用也是最常用到的,如:for、belete、void 等。

② :严格模式下的保留字:这类保留字会在你使用严格模式下列为保留字,如:let 、protected 等。

③ :严格模式下的不完全保留字: 如:arguments、eval ;

④ :ECMAScript3的保留字:如果你希望你的代码运行在基于ECMAScript 3 的解析器上,那么你应该了解一下。

⑤ :ECMAScipt 5 的保留字:class、const 等

⑥ :全局变量和函数: 这类放在保留字,主要是为了避免污染,应该避免以他们的名字定义变量名和函数名,如: Function、encodeURL 等。

 

二、基础保留字:

全部的基础保留字:

break ; delete ; function ; return ; typeof ; case ; do ; if ; switch ; var ; catch ; else ; in ; this ; void ; continue ; false ; true ; instanceof ; throw ; while ; debugger;finally ; new ; with ; default ; for ; null ; try ;
 
1. 我们先来说说循环类的 for / switch / case / default / while / do / continue / break ;
—— 三大基础循环相信大家都是有了解的,这里就只做简单的描述,缺乏基础的同学可以先去W3school 看看;
  
-- 首先简述一下switch / case / default 这三个
var n;
    switch (n) {
        case 2: // ==> if ( n === 2 )
            console.log(1)
        break;
        case '2':
            console.log(2)
        break;
        default:
        console.log('n与上面case的值都不相等时执行 default 内的代码块')
    }

switch 基础


简单的说,你只要把 switch (n) 内的值 n 和 case m 后的值 m 当成是 if () 内执行 n===m 就容易理解了,所以:

var n = '2';
    switch (n) {
        case 2:
            console.log(1)
        break;
        case '2':
            console.log(2)
        break;
        default:  // 传说中的替补队员,存在break的情况下,只有前面都不为真时会触发。
        console.log('n与上面case的值都不相等时执行 default 内的代码块')
    }
// 上面的代码输出的会是->  2 ;


值得提醒一下新人的是,如果不添加 break 语句的话,switch 会继续执行至整个循环结束。例如:

var n = '2';
    switch (n) {
        case 2: // ==> if ( n === 2 )
            console.log(1)
        case '2':
            console.log(2)
        default:
        console.log('我被执行了')
    }
// 输出->  2
// 以及输出-> 我被执行了


-- 来,我们加快步伐,看看 for / for in 语句:
// 平常我们写 for 循环 
    for (var i=0; i<5; i++) {
        console.log(i)
    }
// 依次输出 0 1 2 3 4

// 也可以写成这样
    var i=0,len=5;
    for (; i<len ;) {
        console.log(i)
        i++
    }
// 输出结果是一样的 0 1 2 3 4

// for in 循环
    var data={a=1},x;
    for (x in data) {
        console.log( x )  // a 属性名
        console.log( data[x] )   // 1 属性值
    }
复制代码


--  while / do while 语句:

// while - 当指定的条件为 true 时循环指定的代码块

    var i = 0;
    while (i<3) {   // 如果条件为真,那就继续执行
        console.log(i);
        i++;
    }
// 输出 0 1 2
// 值得注意的是,如果你忘记增加条件中所用变量的值,该循环永远不会结束。该可能导致浏览器崩溃

// do/while 循环
    var i = 3;
    do {
        console.log(i);
        i++;
    }
    while (i<3);
// 输出 3 
// 无论条件是否为真,都先执行一边do内的代码块


-- 接下来比较有趣,我们说说跳出循环的两种保留字(break / continue)和如何给循环命名。
// 跳出循环
// break 语句用于跳出循环。  // 跳出整个循环.
// continue 用于跳过循环中的一个迭代。 // 跳出当前次循环,进入下一个循环。
例如:--break
    for (var i=0; i<5; i++) {
        if(i == 1){
            break;
        }
        console.log(i)
    }
//   输出 0

--continue
    for (var i=0; i<5; i++) {
        if(i == 1){
            continue;
        }
        console.log(i)
    }
// 输出 0 2 3 4



并且我们可以给循环命名,让 continue 或者 break 跳出指定循环,例如:

var text = "";
var i, j;  // => var i; var j
Loop1: // 第一个循环标签 "Loop1"
for (i = 0; i < 3; i++) {
text += "i = " + i + ", j = ";

    Loop2: // 第二个循环标签 "Loop2"
    for (j = 10; j < 15; j++) {
        if (j == 12) {
            break Loop1;
        }
        console.log( text += j + " " );
    }
}

// 第一次输出   i = 0, j = 10 
// 第二次输出   i = 0, j = 10 11


这里我们给第一个循环定义了一个名字,叫 Loop1 ,注意,这里给循环定义的名字和 var 定义变量丝毫不冲突,例如:

var Loop1 = 999;
Loop1 : for (var i = 0; i < 3; i++) {
    console.log(Loop1)
}

// 定义了Loop1,输出的会是三次999;

但是如果不定义变量Loop1,将会抛出错误,只要break和continue可以使用

Loop1 : for (var i = 0; i < 3; i++) {
    console.log(Loop1)
}

// Loop1 is not defined


!!!注意的是,continue只能用于循环,但是我们的break可不止这些,还能跳出代码块,例如:(给某一块代码命名)
cars=["BMW","Volvo","Saab","Ford"];

list: {
    console.log( cars[0] );    // BMW
    console.log( cars[1] );    // Volvo
    console.log( cars[2] );    // Saab
    break list; // 跳出list标签-代码块
    console.log( cars[3] );
    console.log( cars[4] );
    console.log( cars[5] );
}
console.log(list)    // list is not defined
console.log(typeof list) // undefiled


用法是我们可以使用名字xxx:{}去定义一整个代码块,当条件合适的时候跳出,注意,list 不是变量,你在前后定义一个同名变量并不会将之覆盖,现在的写法只是定义了


 来源:https://www.cnblogs.com/csxairou/archive/2018/08/26/9539301.html
 
站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: http://www.fly63.com/article/detial/1032

js中减少使用不必要的if-else或switch_利用数组/对象代替if-else,switch

无论使用if-else,还是switch。当条件多的时候代码显得非常冗长,而且每次添加条件时需要修改主流程的代码,这样就破坏了类的开闭原则。为解决日后的维护可能存在问题,我们可以采用另一种比较优雅的实现方式来替换if-else,switch吗?

js中void 0 与 undefined

偶然看到一个问题:为什么有的编程规范要求用 void 0 代替 undefined?如果不知道这个答案的小伙伴,第一反应就要问void 0是什么鬼?

js中bool值转换以及逻辑运算&&、||、 !!的使用

js作为一门弱类型语言,导致几乎所有数据都能转换为bool的类型,js转换 规则 。了解转换规则目的掌握逻辑运算符&&、||、 !!的使用

你所忽略的js隐式转换

你有没有在面试中遇到特别奇葩的js隐形转换的面试题,第一反应是怎么会是这样呢?难以自信,js到底是怎么去计算得到结果,你是否有深入去了解其原理呢?下面将深入讲解其实现原理。

基于规则评分的密码强度检测算法分析及实现(JavaScript)

用正则表达式做用户密码强度的通过性判定,过于简单粗暴,不但用户体验差,而且用户帐号安全性也差。那么如何准确评价用户密码的强度,保护用户帐号安全呢?本文分析介绍了几种基于规则评分的密码强度检测算法

js 实现栈和队列

js实现栈或者队列有两种方式: 1.数组:数组本身提供栈方法(push,pop),队列方法(push,shift)。 2.链表:构造链表结构,说白了就是链表的插入(尾插),移除(栈:末尾节点移除,队列:头结点移除)

JavaScript 优雅的实现方式包含你可能不知道的知识点【转】

Js优雅的实现方式包含你可能不知道的知识点:简短优雅地实现 sleep 函数,js获取时间戳,js数组去重,js数字格式化,js交换两个整数,将 argruments 对象(类数组)转换成数组,数字取整等

44道JS难题

国外某网站给出了44道JS难题,这些题涉及面非常广,涵盖JS原型、函数细节、强制转换、闭包等知识,而且都是非常细节的东西,透过这些小细节可以折射出很多高级的JS知识点。

JavaScript中变量提升和函数提升的意义理解

在ES6之前,Js中是没有块级作用域的,只存在全局作用域和函数作用域。变量提升即将变量声明提升到它所在作用域的最开始的部分;函数提升只有函数声明中才发生。

浅谈js自记忆函数

最近阅读《JavaScript忍者秘籍》看到了一种有趣的函数:自记忆函数。记忆化(memoization)是一种构建函数的处理过程,能够记住上次计算结果,当函数计算得到结果时,就将该结果按照参数存储起来。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!