前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2015.12.11 HTML5真题练习

2015.12.11 HTML5真题练习

作者头像
HTML5学堂
发布2018-03-12 15:14:56
5160
发布2018-03-12 15:14:56
举报
文章被收录于专栏:HTML5学堂HTML5学堂HTML5学堂

HTML5学堂:每天一道题,强壮程序员!今日主要涉及12.10题目函数以及return(返回值)、预编译执行的解答,以及一道涉及函数递归调用的题目。

HTML5真题【2015.12.10】答案解析

12.10真题题目如下,最终输出的结果是多少?

<script>
// 代码段1
var x = 1;
function b() {
x = 10;
return;
function x() {
console.log('HTML5学堂');
}
}
b();
console.log(x);


// 代码段2
var x = 1;
function b() {
x = 10;
return function x() {
console.log('HTML5学堂');
};
}
b();
console.log(x);
</script>

本题目的答案是:代码段1输出内容为1;代码段2输出内容为10

函数声明可以分为两种,一种是函数表达式声明另外一种是普通函数声明,函数表达式声明不会提前编译,普通函数会提前编译。常见的函数表达式var ftn = function() {}。放在return 里面的函数也是称作为函数表达式声明,所以没有提前编译了,导致函数里面并没有声明x,直接调用父级。

第一段代码,return加分号,所以不能认为函数是作为return的返回值,对于x这个普通函数声明,提前编译了,也就是说函数内部有这个x变量。

第二段代码,return没有加分号,所以认为return的返回值,对于x这个函数表达式声明并没有提前编译了,也就是说函数内部没有这个x变量。

HTML5真题【2015.12.11】题目

<script>
function show(n) {
if (n <= 0) {
return 1;
} else {
return n * show(n - 1);
}
}
console.log(show(5));
</script>

关于每日代码练习题的答案和解析,我们会在明日文章当中,发布相关答案以及基本原理。(PS:周六日不发布题目)

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2015-12-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 懂点君 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • HTML5真题【2015.12.10】答案解析
  • HTML5真题【2015.12.11】题目
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档