前言:
一位前端界的大神让我去思考的一个问题, 给了Big-man一段代码,如下:
function Seriously(options) { // if called without 'new', make a new object and return that if(window === this || !(this instanceof Seriously) || this.id !== undefined) { return new Seriously(options); } }
return语句执行之后还会继续执行吗?这是大神上来让我解决的问题,既然提到了return那我也就随带解决JS中另外的两种结束循环的方法break, continue。
Break语句:
for(var i = 519; i < 550; i++) { if(i == 522) { break; } console.log(i); alert(i); document.write(i); }
Continue语句:
for(var i = 5; i >=0; i--) { if(i == 4 || i == 3 || i == 1) { continue; } console.log(i); alert(i); document.write(i); }
Return语句:
return语句就是用于指定函数返回的值。return语句只能出现在函数体内,出现在代码中的其他任何地方造成语法错误!
for(var i = 1; i < 10; i++) { if(i == 8) { return; } console.log(i); alert(i); document.write(i); }
执行结果Uncaught SyntaxError: illegal return statement(...)
当执行return语句时, 即使函数主题中还有其他语句, 函数执行也会停止!
<script type="text/javascript"> if(username == "") { alert("please input your username: "); return false; } else if (qq == "") { alert("please input your qq number: "); return false; } </script>
上面的实例里,当username为空时,就不会再向下执行,在一些表单提交中,也可以通过return false来阻止默认的提交方式,改用Ajax的提交方式,例如:
<form id="form" onSubmit="return false"> ... </form>
this对应的全局变量:
window == this这个Boolean等式,在不同的情况下的展现都不一样的。
<!DOCTYPE html> <html> <head> <title></title> </head> <body> <script type="text/javascript"> function a() { console.log(window === this) } a(); </script> </body> </html>
这个时候的window === this打印出来的是true,这也就意味着this绝对等于window。
<!DOCTYPE html> <html> <head> <title></title> </head> <body> <script type="text/javascript"> 'use strict' function a() { console.log(window === this) } a(); </script> </body> </html>
这个时候window === this返回回来的值却是false, 而且打印出来的this是undefined的。
所以严格模式下面的代码操作需要更加的规范和合理才可以的。
声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com