文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

javascript中没有名称的函数是什么

2023-06-14 11:17

关注

这篇文章主要讲解了“javascript中没有名称的函数是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript中没有名称的函数是什么”吧!

在javascript中,没有名称的函数叫“匿名函数”,语法“function (){}”。匿名函数的作用:1、通过匿名函数可以实现闭包;2、模拟块级作用域,减少全局变量。

javascript中没有名称的函数是什么

本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

匿名函数:没有实际名字的函数。

首先我们声明一个普通函数:

//声明一个普通函数,函数的名字叫fnfunction fn(){    console.log("hello world");}

然后将函数的名字去掉即是匿名函数:

//匿名函数,咦,运行时,你会发现报错啦!function (){    console.log("hello world");}

到此,你会发现单独运行一个匿名函数,由于不符合语法要求,报错啦!解决方法只需要给匿名函数包裹一个括号即可:

//匿名函数在其它应用场景括号可以省略(function (){    //由于没有执行该匿名函数,所以不会执行匿名函数体内的语句。    console.log("hello world");})

如果需要执行匿名函数,在匿名函数后面加上一个括号即可立即执行!

(function (){    //此时会输出hello world    console.log("hello world");})()

倘若需要传值,直接将参数写到括号内即可:

(function (str){    //此时会输出hello world!    console.log("hello");})(" world!")

匿名函数的应用场景

事件

<input type="button" value="点我啊!" id="sub"><script>    //获得按钮元素    var sub=document.querySelector("#sub");    //给按钮增加点击事件。    sub.onclick=function(){        alert("当点击按钮时会执行到我哦!");    }</script>

对象

var obj={    name:"张三",    age:18,    fn:function(){        return "我叫"+this.name+"今年"+this.age+"岁了!";    }};console.log(obj.fn());//我叫张三今年18岁了!

函数表达式

//将匿名函数赋值给变量fn。var fn=function(){    return "我是一只小小小小留下,怎么飞也飞不高!"}//调用方式与调用普通函数一样console.log(fn());//我是一只小小小小留下,怎么飞也飞不高!

回调函数

setInterval(function(){    console.log("我其实是一个回调函数,每次1秒钟会被执行一次");},1000);

返回值

//将匿名函数作为返回值function fn(){    //返回匿名函数    return function(){        return "hello world";    }}//调用匿名函数console.log(fn()());//hello world//或var box=fn();console.log(box());//hello world

模仿块级作用域

if(1==1){//条件成立,执行if代码块语句。    var a=12;//a为全局变量}console.log(a);//12for(var i=0;i<3;i++){    console.log(i);}console.log(i);//4

if(){}for(){}等没有自己的作用域。如果有,出了自己的作用域,声明的变量就会立即被销毁了。但是咱们可以通过匿名函数来模拟块级作用域:

(function(){    //这里是我们的块级作用域(私有作用域)})();

尝试块级作用域:

function fn(){    (function(){        var la="啦啦啦!";    })();    console.log(la);//报错---la is not defined}fn();

匿名函数的作用:

通过匿名函数可以实现闭包,关于闭包在后面的文章中会重点讲解。在这里简单介绍一下:闭包是可以访问在函数作用域内定义的变量的函数。若要创建一个闭包,往往都需要用到匿名函数。

模拟块级作用域,减少全局变量。执行完匿名函数,存储在内存中相对应的变量会被销毁,从而节省内存。再者,在大型多人开发的项目中,使用块级作用域,会大大降低命名冲突的问题,从而避免产生灾难性的后果。自此开发者再也不必担心搞乱全局作用域了。

感谢各位的阅读,以上就是“javascript中没有名称的函数是什么”的内容了,经过本文的学习后,相信大家对javascript中没有名称的函数是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯