return 的返回值与结束功能
前言:大家好我是阿飞在js中return是很重要的基础。一定要彻底掌握理解它哦。否则js学习到中后期很容易懵逼的+_+
什么是return?
1.在js中return是一个表达式语句,如果后面什么都不写,他的默认返回值为undefined!
2.在函数内,可以用return语句指定返回值。如return 13;,也可以没有返回值。如 return;
3.每个函数都存在一个返回值。但是处于隐身状态!必须通过return体现出。
4.返回值和输出没关系,输出是输出console.log之类的,返回值是返回值!
3.return具有结束的功能!当函数执行到return语句时,不管后面有无代码,都将结束函数的执行。
4.return 必须放在函数内!否则报错
我们先看下默认返回值undefined是什么鬼
例1:
function demo1(){
}
console.log(demo1());
//后台打印
// undefined
例2:
function demo2(){
return;
}
console.log(demo2());
//后台打印
// undefined
tips:由此可见函数内 不管加不加return ,都会存在return返回值。什么都不写的话 默认返回undefined!
接下来我们看下return的结束功能
function demo1(){
console.log("我是阿飞");
console.log("我是最帅");
}
demo1();
//后台打印
//我是阿飞
//我是最帅
function demo2(){
console.log("我是阿飞");
return;
console.log("我是最帅");
}
demo2();
//后台打印
//我是阿飞
tips:由此可见 函数内return后(下方) 的内容便无法显示了。这便是return结束的功能。
我们再来看下 return 必须放在函数内!是啥意思
console.log(1);
return;
console.log(2);
//报错
tips:所以这件事教育我们 return不在函数内的话肯定会报错滴~
另外return还可以运用在for循环和分支语句里
function demo1(){
for (var i = 0; i < 5; i++) {
if (i==2) {
return "over";
}
console.log(i);
}
}
demo1();
//后台打印
//第一行 0
//第二行 1
console.log(demo1());
//后台打印
//第一行 0
//第二行 1
//第三行 over
最后我们还需要深刻理解return结束的作用域!
function demo1(){
for (var i = 0; i < 10; i++) {
if (i==4) {
return;
}
console.log(i);
}
console.log("我不受return影响哟.....才怪");
function demo2(){
console.log("我是demo2,demo1是我的父级,并且return在我上面,所以我无法显示了。。。");
}
demo2();
for (var j = 1; j <10; j++) {
console.log(j);
}
}
demo1();
//后台打印
//0
//1
//2
function demo3(){
console.log("我是demo3,return管不着我!哼")
}
demo3();
//后台打印
//我是demo3,return管不着我!哼
由此可见 return的作用域仅限在自己的函数内。当一个函数里出现return时候,那么它下方的所有代码都不执行了。和他同级的函数他管不着哦~
最后再来一个烧脑搞事情的练习~
function demo(){
return console.log("我要搞事情~");
}
console.log(demo());
猜猜结果是啥?
//后台打印
//我要搞事情~
//undefined
解析:
1.首先return console.log("我要搞事情~"); 打印我要搞事情~
2.console.log()其实本身就是一个函数,我们都知道函数里都有返回值,而返回值必须通过return才能显示出来。
3.console.log("我要搞事情~");显然这个函数里并没存在return 所以当函数没有设置return,或者return后面不写数值的时候。默认undefined
总结
提问1:阿飞~我分不清return返回值的位置,和return结束功能的位置欸。。。O.O
回答1:通常你想要返回值的时候添加return,一般写在函数最下方。如果你想结束功能时候,return的位置不一定。
提问2:阿飞~我表示还是分不清return的返回值和结束区别欸。。。O.O
回答2:最简单的鉴别方法是:当你写console.log(函数调用)时候会出现返回值(其实此刻出现返回值后同时也具有结束的功能)。---------------------其他时候return都是具有结束功能。不会显示出返回值(注意:不显示不代表不存在!!!,但是因为return是个表达式,所以他其实依旧存在返回值,只是暂时没显示而已)
return 的返回值与结束功能的更多相关文章
- defer、return、返回值,这三者的执行逻辑
defer.return.返回值,这三者的执行逻辑是: return 最先执行,return 负责将结果写入返回值中:接着defer执行,可能修改返回值:最后函数携带当前返回值退出.
- go中defer的理解--defer、return、返回值之间执行顺序
defer可以读取有名返回值 func c() (i int) { defer func() { i++ }() return 1 } 输出结果是2. 在开头的时候,我们知道defer是在return ...
- Golang中defer、return、返回值之间执行顺序的坑
原文链接:https://studygolang.com/articles/4809 Go语言中延迟函数defer充当着 cry...catch 的重任,使用起来也非常简便,然而在实际应用中,很多go ...
- 获取的ajax方法return的返回值的问题解析
今天刚上班就偶遇关于获取Ajax方法return的返回值的问题,这里小记一下. 在使用jquery中,如果获取不到ajax返回值,原因有二: 一.ajax未使用同步 ajax未使用同步,导致数据未加载 ...
- jquery中ajax用return来返回值无效
jquery中,ajax返回值,有三种写法,只有其中一种是成功的 /** * async:false,同步调用 * 返回1:2 * 失败 * 分析:ajax内部是一个或多个定义的函数,ajax中ret ...
- jquery ajax 不执行赋值,return没有返回值的解决方法
大家先看一段简单的jquery ajax 返回值的js 复制代码 代码如下: function getReturnAjax{ $.ajax({ type:"POST", url:& ...
- ajax jquery return没有返回值
错误写法: function editdivisionmember(division_id,users_id){ $.ajax({ type:"POST", url:"/ ...
- 函数返回值 return
return 返回值 (后面跟的是数据类型) // 数字.字符串.布尔.函数.对象(元素.[].{}.null).未定义return:返回值 1)函数名+括号:fn1() ==> return ...
- 函数的返回值return
'''1.什么是返回值 返回值是一个函数的处理结果 2.为什么要有返回值 如果我们需要在程序中拿到函数的处理结果做进一步的处理,则需要函数必须有返回值 3.函数的返回值的应用 函数的返回值用retur ...
随机推荐
- HashTable的故事----Jdk源码解读
HashTable的故事 很早之前,在讲HashMap的时候,我们就说过hash是散列,把...弄碎的意思.hashtable中的hash也是这个意思,而table呢,是指数据表格,也就是说hasht ...
- 虚拟机Linux系统下配置网络
虚拟机上安装Redhat9.0后是没有网络的,而本来的Windows系统是可以上网的,此时想在Redhat上网就需要在Linux系统上配置网络,以下是笔者自己配置的一点心得. 1.电脑本机系统打开网络 ...
- jenkins,SVN构建总是clean目录,回归失败
近期发现配置的jenkins任务打包时间极长,经过定位为svn版本的问题,不同的svn版本.svn的信息存在不一致. 解决: 升级服务器svn版本. 调整jenkins系统设置: 测试通过(回滚成功) ...
- 【JAVASCRIPT】React 学习 - 登录实战
摘要 实现一个登录的react 组件, 包含组件更新.ajax 交互.渲染新组建. 代码 <head> <meta charset="utf-8"> < ...
- 关于javacc的认识
http://www.cnblogs.com/Gavin_Liu/archive/2009/03/07/1405029.html
- jsp元素
1.指令元素:用于在JSP转换为Servlet阶段提供JSP页面的相关信息,如页面采用的字符编码集.页面中需要导入的类等信息,指令元素不会产生任何的输出到当前JSP的输出流中 指令元素有三种指令:pa ...
- InnoDB关键特性之刷新邻接页-异步IO
Flush neighbor page 1.工作原理 2.参数控制 AIO 1.开启异步IO 一.刷新邻接页功能 1.工作原理 当刷新一个脏页时,innodb存储引擎会检测该页所在区(extent)的 ...
- css3关键帧动画实现轮播效果
实现效果:打开手机京东,可以看到首页的头部,以这个头部为基础,仿写一个类似的样式. 思路:仔细观察可以发现,手机京东的头部是以一个搜索栏和轮播特效组成的,而这个搜索栏是以轮播特效做为背景的,现在运用c ...
- C#设计模式(1)-单例模式
单例(Singleton)模式介绍 单例模式:也可以叫单件模式,官方定义:保证一个类仅有一个实例,并提供一个访问它的全局访问点. 单例模式的特点: 单例类只能有一个实例. 单例类必须自己创建自己的唯一 ...
- 移动端300ms点击事件的延迟
移动端click事件300ms延迟 移动端click事件300ms的延迟在目前看来,已经是老生常谈了. 以下内容,我会在参考资源的基础上谈谈我对移动端click事件300ms延迟的一些理解.本人愚昧, ...