js2-switch语句 for循环 break和continue语句 函数 全局变量和局部变量

switch语句

  //格式
 switch (值){  //switch中的值,可以是数字,可以是字符串,甚至可以是表达式
    case 值1:
         代码1;
         break;  //不能省略break,省略会有贯穿问题,代码会一直往下执行,直到遇到break 为止
    case 值2:
         代码2;
         break;
         ...
    default:
         代码n;
}
  • 执行到break就结束switch语句
  • 执行过程
    • switch语句根据传入的值进行对比, 匹配case中的值, 就执行case中的代码
    • 没有匹配值, 就执行default里的代码
  • switch性能比if高, 但if使用频率在开发中用的多

for循环

//格式
for (初始语句; 循环判断语句; 末尾语句 ){
    循环体 (一段代码)
}
  • 初始语句: 在循环之前执行, 一般定义一个初始值为0的变量
  • 循环判断语句: 如果条件为真, 就执行循环体
  • 末尾语句: 循环一次之后执行, 一般是对初始值中的变量自增或自减
  • 循环体: 反复执行的一段代码

break和continue的区别

  • break在循环中, 立即退出循环, 强制执行循环后的语句(不执行下一次循环)
  • continue在循环中, 立即退出循环(continue后的语句都不执行), 但是从循环的顶部继续执行(执行下一次循环)

while语句

while (条件){
    循环体
}

 do{
    循环体
 }while(条件);
  • while中一定要条件限制(如i++),如果没有就是死循环
  • do..while,至少执行一次循环(哪怕条件为假)

函数

function 函数名(参数1 ,参数2,....) {
        代码块
 }
  • 函数的声明:
    • 往内存中保存一段代码
    • 函数命名规则和变量的命名规则一致
    • 参数: 就是一个变量, 在函数生命中变量用于接收从外部传过来的值
  • 函数的调用:
    • 函数名();
    • 就是从内存中获取代码块执行的过程
  • 函数的参数:
    • 有参数的函数叫有参函数, 无参数的函数叫无参函数
    • 形参: 形式参数, 函数声明时定义的参数, 形参是用来接收实参传过来的值
    • 实参: 实际参数, 函数调用时定义的参数, 往里面传的值, 变量, 表达式都可以
  • 注意: 函数使用前, 需要先声明再调用
函数的返回值
  • return的两个作用
    • 函数返回值
    • 结束函数, 不再往下执行
  • 函数根据返回值可分为:
    • 有返回值得函数, 无返回值的函数
函数的4种类型
  • 无参数无返回值函数

    function sum(){  //函数声明
      var a=1, b=1;
      console.log(a+b);
    }
    sum();   //函数调用
    
  • 无参数有返回值函数

    function sub(){
      var a=1, b=1;
      return a-b;
    }
    console.log(sub());
    
  • 有参数无返回值函数

    function mult(a, b){
        console.log(a* b);
    }
    mult(1, 1);
    
  • 有参数有返回值函数

    function div(a, b){
        return a/b;    //不写return, 函数调用返回undefined
    }
    console.log(div(1, 1));
    
  • 注意: 函数没有重载, 函数名相同(接受的参数类型数量不同即可), 后定义的函数会覆盖先定义的函数, 所以函数名不能相同

函数的注意点
  • 有参函数, 实参的个数 > 形参的个数, 形参会依次从左往右取实参的值
  • 有参函数, 实参的个数 < 形参的个数, 没有接受值得形参值为undefined, 运行结果为NaN
  • 函数不能自己调用自己, 将造成死循环(除非有限制条件, 递归调用)
  • 函数名.length: 获取形参的参数个数
  • arguments.length: 获取实参的参数个数

全局变量 局部变量

js作用域是根据函数来划分的, 变量存在的范围就是作用域.

全局变量
  • 定义: js中函数外部的变量就是全局变量, 可以在任何地方使用的变量
  • 作用域: script开始标签到结束标签之间的范围
  • 注意: 全局变量要先声明初始化后, 才能使用
局部变量
  • 定义: 在函数内部的变量就是局部变量
  • 作用域: 函数花括号里的范围
  • 注意:
    • 局部变量在函数外取不到
    • 局部变量若和全局变量同名, 局部变量会屏蔽全局变量作用范围
    • 变量取值遵循就近原则, 如果使用一个变量, 会在当前范围内找, 一层一层往上找, 直到最上面也没就报错
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容