美文网首页
js 任务 3

js 任务 3

作者: 暂时没有好名字 | 来源:发表于2017-04-03 10:12 被阅读0次

1函数声明和函数表达式有什么区别

在javascript中,函数有两种定义写法,函数定义表达式和函数声明,其例子分别如下所示:

var test = function(x){

return x;

}

function test(x){

return x;

}

尽管函数定义表达式和函数声明语句包含相同的函数名,并且都创建了新的函数对象,但是这二者却有区别。

函数声明语句中的函数名是一个变量名,变量指向函数对象。

函数定义表达式和通过var声明变量一样,其函数被提前到了脚本或函数的顶部,因此它在整个脚本和或函数内都是可见的。这样的话,只有函数变量声明提前了,函数的初始化代码仍然在原来的位置。但是使用函数声明的话,函数名称和函数体均提前了,即脚本中的函数和函数中嵌套的函数都会在当前上下文中其它代码之前声明,也即可以在声明一个函数之前调用它。

举个例子:

test(1);

function test(x){

console.log(x);

}

上述代码能正常执行,结果输出为1;因为对于函数声明语句,函数名称和函数体均提前声明了,可以在声明之前调用它。

test(1);

var test = function(x){

console.log(x);

}

上述代码不能正常执行,会报错。

因为对于函数定义表达式,只有函数变量声明提前了,但是函数的初始化代码仍然在原来的位置,也即相当于如下的代码

var test;   //函数变量声明提前

test(1);

var test = function(x){

console.log(x);

}

因此,会报错test不是一个函数的错误。

2什么是变量的声明前置?什么是函数的声明前置

avaScript引擎的工作方式是,先解析代码,获取所有被声明的变量,然后再一行一行地运行。这造成的结果,就是所有的变量的声明语句,都会被提升到代码的头部,这就叫做变量提升(hoisting)。

3arguments 是什么

arguments 是一个类数组对象。代表传给一个function的参数列表。

arguments[0]就是第一个参数,arguments[1]就是第二个参数,以此类推。这个对象只有在函数体内部,才可以使用。

4函数的"重载"怎样实现

arguments 是一个类数组对象。代表传给一个function的参数列表。

arguments[0]就是第一个参数,arguments[1]就是第二个参数,以此类推。这个对象只有在函数体内部,才可以使用。

function showSum()

{

//使用arguments对象模拟出重载效果

if (arguments.length == 1)

{

alert(arguments[0] + 1);

}

else if (arguments.length == 2)

{

alert(arguments[0] + arguments[1]);

}

else if (arguments.length == 3)

{

alert(arguments[0] + arguments[1] + arguments[2]);

}

else {

alert('请传入参数!');

}

}

//显示101

showSum(100);

//显示200

showSum(100, 100);

//显示300

showSum(100, 100,100);

functionshowSum(){//使用arguments对象模拟出重载效果if(arguments.length ==1)

functionshowSum(){//使用arguments对象模拟出重载效果if(arguments.length ==1)

functionshowSum(){//使用arguments对象模拟出重载效果if(arguments.length ==1)

5立即执行函数表达式是什么?有什么作用

(function(){    ...})();

(function(){    ...}());

作用:

通常情况下,只对匿名函数使用这种“立即执行的函数表达式”。它的目的有两个:一是不必为函数命名,避免了污染全局变量;二是IIFE内部形成了一个单独的作用域,可以封装一些外部无法读取的私有变量。

6求n!,用递归来实现

functionmultiply(n){if(n===1){return1;    }returnn*multiply(n-1);}multiply(3);//6

相关文章

  • js 任务 3

    1函数声明和函数表达式有什么区别 在javascript中,函数有两种定义写法,函数定义表达式和函数声明,其例子分...

  • 任务:进阶3:JS函数

    前言 在程序设计语言里面有一种语句叫决策语句,可以使程序根据是否满足特定的条件,运行相对应代码。换言之,决策语句使...

  • 面试题【Day11】

    本篇绪论 1, 宏任务、微任务 2,创建对象 3,instanceof 1, 宏任务、微任务 JS是单线程执行的语...

  • 十九、JS中的同步异步(Event Loop)------ 20

    1、浏览器执行JS代码的机制: 2、等待任务队列(Event Queue): 3、简单例子(未区分宏任务、微任务)...

  • 浏览器JS事件循环

    单线程 js引擎使用一个主线程来执行js代码,所以js同时仅能执行一个任务。 同步任务与异步任务 同步任务 在主线...

  • React Native Headless JS(后台任务)

    React Native Headless JS(后台任务) Headless JS是一种使用js在后台执行任务的...

  • JavaScript 事件循环(宏任务微任务)

    JavaScript 事件循环 宏任务微任务 JavaScript 的执行机制 js 是单线程的,js 任务需要一...

  • js - 微任务 宏任务

    1. 概念理解 1.1 JavaScript是单线程语言:单线程: 同一个时间只能做一件事; js是单线程语言, ...

  • 宏任务和微任务

    [js 宏任务和微任务] .宏任务(macrotask )和微任务(microtask ) macrotask 和...

  • 浏览器中的事件循环

    记忆核心: JS执行: 同步任务在JS主线程(属于渲染进程的线程)执行 异步任务进入任务队列(由事件触发线程维护)...

网友评论

      本文标题:js 任务 3

      本文链接:https://www.haomeiwen.com/subject/kilgottx.html