2015.12.11 HTML5真题练习

时间:2022-05-03
本文章向大家介绍2015.12.11 HTML5真题练习,主要内容包括HTML5真题【2015.12.10】答案解析、HTML5真题【2015.12.11】题目、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。

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:周六日不发布题目)