1. if-else if       ---------适用于区间范围的判断

If(判断条件--一般是boolean类型的值或是关系表达式或是逻辑表达式

){

要执行的代码;

}else if(判断条件){

要执行的代码;

}…

执行过程:先判断if小括号内的条件是否成立,如果成立,就返回true继续执行if大括号内的代码,如果if小括号内的条件不成立,就返回false,然后判断else if括号里的内容,如果成立,同样返回true,继续执行else if大括号内的内容,小括号内的条件不成立就返回false,然后判断下一个else if…

  1. 三元运算符:

表达式1(关系表达式或是逻辑表达式)? 表达式2:表达式3;

执行过程:先判断表达式1中的内容是否成立,也就是返回true,如果正确则表达式2的值就是整个表达式的结果,如果表达式1的内容不成立,也就是返回false,则表达式3的值就是整个表达式的结果。

  1. Switch-case    ----------适用于定值的判断

switch(值--一般是一个变量或是计算后的定值){

case 值1:

要执行的代码;

break;

case 值2:

要执行的代码;

Break;

Case 值3:

要执行的代码;

Break;

Default:

要执行的代码;

Break;

}

执行过程:

当程序执行到switch处,先进入小括号,计算里面值,然后拿着这个定值依次和大括号中case里面的值进行匹配,如果匹配成功,则执行对应的case中的代码,遇到break,则跳出当前swicth-case结构,如果匹配都不成功,则要看结构是否有default,如果有,则执行default中的代码,遇到break跳出结构,如果没有default,则直接跳出swicth-case结构,执行后面的代码。

4.短路运算小结

&& :(找假)

如果两边是布尔类型,则最后返回的值要么是true,要么是false。

例: var a=12>10&&10>14;

Console.log(a);

分析:先判断&&都是布尔类型,左边为true,右边返回false,因为&&是找假的所以最后的结果是false;

如果&&两边都不是布尔类型,会先将两边转化为布尔类型返回,返回的值是false的那一边的操作数。

例:var b=”abc”&&”bcd”;

console.log(b);

分析:先判断&&两边不是布尔类型,但是都是为真的,因为&&是找假的一方返回,所以先判断左边是真,则跳过,此时不管右边是真是假都返回右边的值。结果是bcd.

如果两边都是false值,那么就返回第一个值。

例:var c=NaN&&undefined;

Console.log(c);

分析:先判断&&两边都不是布尔类型,需要转换,都是false,所以返回第一个值,最后的结果是NaN.

|| : (找真)

如果||两边都是布尔类型,则返回的值要么是true要么是false.

Var d=10<10||10<12;

Console.log(d);

分析:首先||两边都是布尔类型,再判断左边为假,右边为真,而||是找真的,所以返回的是右边的布尔值,最后结果为true.

如果||两边都不是布尔类型,则先将左右对象转化成对应的布尔类型的值,然后再返回布尔类型所对应的值。转换之后如果第一个值所对应的布尔值为true,则返回第一个值,否则就返回第二个值。

Var e=”abc”|| “cde”;

Console.log(e);

分析:||左右不是布尔类型,开始转化左右为布尔类型,左边为正,因为||找真,所以直接返回左边的true所对应的值,结果为abc.

逻辑!(非)

如果操作数是对象,返回false

如果操作数是空字符串,返回true

如果操作数是非空字符串,返回false

如果操作数是0,返回true

如果操作数是任意非0值,返回false

如果操作数是null,undefined,NaN,返回true

上面的规则可以简化成

转换为false的值:false、""、0和NaN、null、undefined

5.while

循环: 所谓循环就是重复的做同一件事情

while 循环

while(循环条件){

循环体(要执行的代码);

}

执行过程:当程序 运行到while处,首先进入小括号判断循环条件是否成立,如果成立,也就是值为true,则进入大括号执行里面的循环体,执行完毕之后,再次回到小括号中判断 循环条件是否成立,如果成立则再次进入大括号执行里面的循环体,往复循环。

6.do-while

Do{

循环体;

} while(循环条件)

执行过程:

程序执行到do处,先进入大括号执行里面的循环体,然后带着执行结果到达while的小括号,判断里面的循环条件是否成立,如果成立,则再次进入大括号执行里面的循环体,如果不成立,则跳出当前do-while循环。

Do-while与while的区别:

Do-while至少执行一次循环体,然后再判断 循环条件。

While先判断循环条件,再执行循环体,有可能 一次循环体都不执行。

7.for循环

一般多用于已知次数的循环

for(表达式1;表达式2;表达式3){

循环体;

}

执行过程:

程序运行到for处,进入小括号中,先执行表达式1,声明变量,并赋初值,然后执行表达式2,判断循环条件是否成立,如果条件成立,则进入大括号执行里面的循环体,第一次循环的时候,并不执行表达式3,第一次循环执行完毕之后,执行表达式3,改变循环条件,然后再执行表达式2,判断循环条件是否成立,如果成立,则再次执行循环体,如果不成立,则跳出循环。

循环的嵌套,外层循环循环一次,内层循环n次。

8.break与continue的区别:

Break;

两种用法 :

第一种用在swicth-case 用于跳出当前程序

第二种,是用在循环当中,一般是用while或是for循环当中,与if搭配使用,作用就是立即跳出当前循环,后面的代码都不再执行。

也常见用于死循环的跳出。

While(true){

}

Continue:

一般也是用于循环当中,当遇到continue关键字的时候,立马停止本次循环,然后回到循环条件处,判断 循环条件是否成立,如果成立则继续下一次循环,如果不成立,则退出当前循环。

只结束当前本次循环,continue后面的代码都不再执行。

9.数组

创建数组的两种方式。

// 第一种,用构造函数的方式创建 数组
//        var arr=new Array();
//        arr[0]=100;
//        arr[1]=99;
//        arr[2]=98;
//        arr[10]=23;
//        console.log(arr.length);
//        console.log(arr);
//        //第二种创建数组
        var arr=[12,12,32,true,undefined,"abc",null];
        console.log(arr[2]);
        console.log(arr[arr.length-1]);

学习js第二天小结的更多相关文章

  1. 学习js第一天小结

    1.JavaScript的书写方式: <script type="text/javascript">     </script> <script sr ...

  2. 《DOM Scripting》学习笔记-——第二章 js语法

    <Dom Scripting>学习笔记 第二章 Javascript语法 本章内容: 1.语句. 2.变量和数组. 3.运算符. 4.条件语句和循环语句. 5.函数和对象. 语句(stat ...

  3. 学习KnockOut第二篇之Counter

                                                                        学习KnockOut第二篇之Counter        欲看此 ...

  4. GopherChina第二天小结

    GopherChina第二天小结 今天继续昨天的文章,参加了第二天的GopherChina,例行完成总结. 基于MINIO的对象存储方案在探探的实践 关于对象存储,之前用过seaweedfs,但是对M ...

  5. Vimtutor(中文版)学习笔记各章小结

    在Bash中直接输入 vimtutor 打开新世界!通常阅读完需要25-30分钟不等,像玩游戏一样学会vim,然后爱不释手 里面设置了很多例子通过实践操作来学,这里仅把vimtutor上的每一章小结记 ...

  6. OO第二单元小结

    OO第二单元小结 一.三次作业代码分析. 1.第一次作业 第一次作业是单部电梯的傻瓜调度,由于其过分傻瓜,所以第一次作业我只有两个类,一个main,一个电梯,main类负责不断从输入流中读取命令,如果 ...

  7. 学习js回调函数

    <!DOCTYPE HTML> <html> <head> <meta charset="GBK" /> <title> ...

  8. 《JavaScript权威指南》学习笔记 第二天 下好一盘大棋

    前段学习js的时候总是零零散散的,以至于很多东西都模棱两可.时间稍微一久,就容易忘记.最主要的原因是这些东西,原来学的时候就不是太懂,以至于和其他知识无法形成记忆链,所以孤零零的知识特别容易忘记.重温 ...

  9. RabbitMQ学习总结 第二篇:快速入门HelloWorld

    目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...

随机推荐

  1. STM32的ISP下载程序方式:

    STM32的板子的串口ISP下载方法:Boot0接到3.3V上,Boot1接到GND,对板子重新上电,STM32单片机重启的时候,会进入到ISP模式.

  2. web 对接 platform

    一个项目拆成web和platform,web不对接数据库,只调用各个platform,每个平台负责出一个httpclient的client-jar包,封装好curd方法给web端调用,入参和出参用ja ...

  3. LOJ 2586 「APIO2018」选圆圈——KD树

    题目:https://loj.ac/problem/2586 只会 19 分的暴力. y 都相等,仍然按直径从大到小做.如果当前圆没有被删除,那么用线段树把 [ x-r , x+r ] 都打上它的标记 ...

  4. py-day2-1 python 列表类 list的调用反法

    # append() 追加 [在原来值最后追加] test = [1,2,3,[88,99],'abc'] test.append(') print(test) [1, 2, 3, [88, 99], ...

  5. locate命令详解

    Linux locate命令 locate(locate) 命令用来查找文件或目录. locate命令要比find -name快得多,原因在于它不搜索具体目录,而是搜索一个数据库/var/lib/ml ...

  6. dom实例,模态框,全选,反选,取消

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. html-display标签

    标签可以分为行内标签和行间块级标签, 块级标签:占一行,如果父标签没有限高度,子标签会自动扩展父标签的高度,行内标签不能, 可以设置宽度 高度 padding margin 行内标签:    不能设置 ...

  8. https 不检验证书

    System.Net.ServicePointManager.ServerCertificateValidationCallback += (s, cert, chain, sslPolicyErro ...

  9. 黄聪:PHP调试显示所有错误信息

    ini_set('display_errors',1); //错误信息 ini_set('display_startup_errors',1); //php启动错误信息 error_reporting ...

  10. TCP/IP学习20180627-数据链路层-ethernet

    ifconfig :查看主機支持的網絡協議eth0:以太網接口lo:loopback接口 以太网(Ether-net)的定是指数字设备公司( Digital Equipment Corp.).英特尔公 ...