高程(3):操作符、for、for...in循环、break/continue/return语句、函数等
1、关系操作符
注意点:1)比较操作数是两个字符串,是比较字符串的字符编码值。
如:"a" > "b" 返回 false;"a" > "B" 返回 true;
2)[特别注意]如果是比较两个数字类型的字符串,也是按照字符编码值比较。
如:"256" > "6" 返回 false;
2、相等==和全等===
区别:相等比较有隐式类型转换,而全等则没有类型和数据都要相等才能返回true。
3、逗号操作符
注意点:下面代码中的写法注意区分,b2会变成全局变量
function show(){
var a1 = 1, a2 = 2;
var b1 = b2 = 3;
}
console.log(b2); //b2成为全局变量
4、for循环
注意点:如下代码,for循环内部定义的变量是父级作用域的变量,for、if循环没有内部块级作用域
for(var i = 0; i < 10; i++){
var a = 3;
}
5、for...in...循环:一般用于循环处理json、object,获取key、value做后续处理。
注意点:由于object对象的属性没有顺序,故for...in...循环输出的属性名顺序是不可预测的。
var json = {
"23": 23,
"12": 12,
"2": 2
};
for(var key in json){
console.log(key); //分别返回 2,12,23
}
6、break、continue、return语句区别
1)break:跳出上一级for循环
var num = 0;
function show(){
for(var i = 0; i < 10; i++){
if(i%5==0){
break;
}
num++;
}
num++;
}
show();
console.log(num); //返回1
2)continue:跳出当前次的后续操作,继续下一次for循环操作。
var num = 0;
function show(){
for(var i = 0; i < 10; i++){
if(i%5==0){
continue;
}
num++;
}
num++;
}
show();
console.log(num); //返回9
3)return:跳出当前函数
var num = 0;
function show(){
for(var i = 0; i < 10; i++){
if(i%5==0){
return;
}
num++;
}
num++;
}
show();
console.log(num); //返回0
7、switch语句:如果有又臭又长的if,可以用switch来处理,更加清晰、易于维护
注意点:switch的case操作可以使用表达式。
var num = 10;
switch(true){
case num < 0: alert('<0');
break;
case num > 0: alert('>0');
break;
case num == 0: alert('=0');
break;
}
8、函数
注意点:理解函数参数
函数内部的arguments类数组永远对应调用函数时所传的实参
function abc(a, b){
//此时 a = arguments[0] = 2; b = undefined;
b = 3; //b = 3;
arguments[1] = 4; // 不变
return b; //返回 3
}
cosole.log(abc(2)); //
function abc(a, b){
//此时 a = arguments[0] = 2; b = arguments[1] = 8;
b = 3; //b = arguments[1] = 3;
arguments[1] = 4; // b = arguments[1] = 4;
return b; //返回 4
}
cosole.log(abc(2, 8)); //
function abc(a, b){
console.log(arguments.length); //
arguments[1] = 2;
console.log(b); //undefined
console.log(arguments.length); //
}
abc(2);
PS:1)js中函数没有重载,定义同名函数,后面的函数会覆盖前面函数。
2)可以根据arguments参数的个数判断,来处理不同个参数情况下对程序的控制。
function fn(){
if(arguments.length == 1){
return arguments[0] + 10;
}else if(arguments.length == 2){
return argument[0] + arguments[1] + 20;
}
}
建议:有参数时使用json对象的形式作为参数传递,好处:1)简洁明了;2)可维护性高
function fn(options){
options.a = options.a || "10"; //默认赋值10
for(var key in options){ console.log(key, options[key])}
}
fn({
a: 1,
b: 2
})
高程(3):操作符、for、for...in循环、break/continue/return语句、函数等的更多相关文章
- Java——break,continue,return语句
break语句: break:用于改变程序控制流 用于do-while.while.for中时,可跳出循环而执行循环后面的语句. break的作用:终止当前循环语句的执行. break还可以用来终止s ...
- 退出循环break,continue,return,goto分析
/* 在循环中间设置单个或者多个退出点,可以使用的语句有:break语句.continue语句.goto语句. return */ (1)break :break语句语句用于循环或 switch 语句 ...
- js中的break ,continue, return (转)
面向对象编程语法中我们会碰到break ,continue, return这三个常用的关键字,那么关于这三个关键字的使用具体的操作是什么呢?我们在使用这三关键字的时候需要注意和需要理解的规则是什么呢? ...
- 详解C#break ,continue, return
C#编程语法中break ,continue, return这三个常用的关键字的学习对于我们编程开发是十分有用的,那么本文就向你介绍break ,continue, return具体的语法规范. C# ...
- 有关于break,continue,return的区别和代码分析
今天,用代码和结果直接解释break,continue,return的区别 1.break代码 public static void breakTest() { //break的讲解 for(int ...
- js中的break,continue,return
js中的break,continue, return (转) 面向对象编程语法中我们会碰到break ,continue, return这三个常用的关键字,那么关于这三个关键字的使用具体的操作是什么呢 ...
- break,continue,return的区别
break,continue,return的区别 break 当break语句用于循环语句时,会终止执行循环,并执行循环后代码(如果有的话). function main() { for(var i ...
- Java流程控制,for,switch,while.break,continue,return
Java流程控制,for,switch,while.break,continue,return
- 控制 if 语句 while循环 break continue
if 语句的语法: 1. if 条件 : #引号是将条件与结果分开 代码块 # 四个空格,或者一个tab键,这个是告诉程序满足这个条件的 说明: 当条件成立的时候(True), 代码块会被执行 ...
随机推荐
- 安全测试 - 抓包工具BurpSuite
Brup SuiteBurpSuite是用于攻击web应用程序的集成平台.它包含了许多工具,并为这些工具设计了许多接口,以促进加快攻击应用程序的过程.所有的工具都共享一个能处理并显示HTTP消息,持久 ...
- vs2015 编译时错误列表中没有错误,dll却没有生成出来
最近发现vs2015的一个问题, 编译时,错误列表中没有错误,dll却没有生成出来,vs重启也无效 解决: 多次排查发现如果一个类库设置的是framework 4.0版本,但引用了framework4 ...
- [LeetCode] Number of Segments in a String 字符串中的分段数量
Count the number of segments in a string, where a segment is defined to be a contiguous sequence of ...
- [LeetCode] House Robber 打家劫舍
You are a professional robber planning to rob houses along a street. Each house has a certain amount ...
- C#进阶系列——WebApi 身份认证解决方案:Basic基础认证
前言:最近,讨论到数据库安全的问题,于是就引出了WebApi服务没有加任何验证的问题.也就是说,任何人只要知道了接口的url,都能够模拟http请求去访问我们的服务接口,从而去增删改查数据库,这后果想 ...
- R - MQ
1. rabbit MQ 安装 Rabbit MQ 是建立在强大的Erlang OTP平台上,因此安装Rabbit MQ的前提是安装Erlang.通过下面两个连接下载安装3.2.3 版本: 下载并安装 ...
- Codeforces #364 DIV2
~A题 A. Cards time limit per test 1 second memory limit per test 256 megabytes input standard input ...
- 第一次源码分析: 图片加载框架Picasso源码分析
使用: Picasso.with(this) .load("http://imgstore.cdn.sogou.com/app/a/100540002/467502.jpg") . ...
- 把url参数转化成一个对象返回
var readUrlToParams = function () { var url = location.href; var nameValue; var paraString = url.sub ...
- Unity Animator动画状态机 深入理解(三)二维混合树
介绍二维之前,先说说一维吧~ 这个是通过旋转角度速度快慢来表现身体的大转和中转~ 通过一个-133~133的数值来进行控制. 注:后面的那个对钩是镜像的意思. 其实二维混合树并没有想象中的那么难.先来 ...