位置: 编程技术 - 正文

浅谈javascript 函数表达式和函数声明的区别(javascript中的函数该如何理解)

编辑:rootadmin

推荐整理分享浅谈javascript 函数表达式和函数声明的区别(javascript中的函数该如何理解),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js函数的作用,javascript中的函数该如何理解,简述javascript中的函数,javascript函数,javascript函数的作用,js函数的作用,javascript函数如何定义及其作用,javascript函数,内容如对您有帮助,希望把文章链接给更多的朋友!

javascript中声明函数的方法有两种:函数声明式和函数表达式.

区别如下:

1).以函数声明的方法定义的函数,函数名是必须的,而函数表达式的函数名是可选的.

2).以函数声明的方法定义的函数,函数可以在函数声明之前调用,而函数表达式的函数只能在声明之后调用.

3).以函数声明的方法定义的函数并不是真正的声明,它们仅仅可以出现在全局中,或者嵌套在其他的函数中,但是它们不能出现在循环,条件或者try/catch/finally中,而

函数表达式可以在任何地方声明.

下面分别用两种方法定义函数:

下面一个有趣的javascript:

会输出什么呢&#;第一反应应该是"I am outside"吧. 结果在chrome中输出"I am inside",IE直接报错,firefox低一点的版本输出"I am outside"...

chrome输出的结果很明确的反应了用函数声明式声明的函数的特点--函数在声明之前就可以调用.

IE报错显示缺少对象,因为函数声明在了条件里,违背了函数声明式的原则.

函数表达式的作用域:

如果函数表达式声明的函数有函数名,那么这个函数名就相当于这个函数的一个局部变量,只能在函数内部调用,举个栗子:

fact()在函数内部可以调用,在函数外部调用就会报错:fact未定义.fact

我们再来详细看下

函数声明

  函数声明示例代码

代码如下:

  这样我们就声明了一个名称为fn的函数,这里出个思考,你认为在这个函数的上面来调用他的话会执行吗?还是会报错?

代码如下:fn(); // 在之前调用我们声明的fn函数 function fn () { console.log('fn 函数执行..'); // code..}

  控制台输出结果:

浅谈javascript 函数表达式和函数声明的区别(javascript中的函数该如何理解)

  是的,此时fn函数是可以被调用到的,这里来总结下原因。

总结:

  1:此时fn函数是变量的结果,默认存储在全局上下文的变量中(可用 window.函数名 来验证)

  2:此方式为函数声明,在进入全局上下文阶段创建,代码执行阶段,它们已经可用。ps:javaScript在每次进入方法时都会先初始化上下文环境(由全局 → 局部)

  3:它可以影响变量对象(仅影响存储在上下文中的变量)

函数表达式

  函数表达式示例代码

代码如下:

  这样我们就声明了一个匿名函数,并且把它的引用指向了变量fn?

  再次在该表达式声明的函数上下方各调用一次,来看控制台的输出结果。

代码如下:

  控制台打印结果:

  可以看到代码在执行到第一次调用fn()函数的时候,提示:fn is not a function (fn 不是一个方法),遇到错误而终止运行。

  这说明在第一次调用fn()的同时,var fn 变量没有做为全局对象的一个属性而存在,且 fn 引用的匿名函数上下文也没有被初始化,所以在他之前调用失败。

代码如下:

  控制台打印结果:

  可以看出,在该表达式函数之后来调用是可以的,来总结下那是为什么呢?

总结:

  1:首先变量本身不做为一个函数存在,而是一个匿名函数的引用(值类型的不属于引用)

  2:在代码执行阶段,初始化全局上下文时,它没有被做为全局的一个属性而存在,所以不会造成变量对象的污染

  3:该类型的声明一般在插件的开发比较常见,也可做为闭包中回调函数的调用

  所以 function fn () {} 并不等于 var fn = function () {} ,他们有本质上的区别。

标签: javascript中的函数该如何理解

本文链接地址:https://www.jiuchutong.com/biancheng/384706.html 转载请保留说明!

上一篇:JavaScript实现下拉菜单的显示和隐藏(js实现下载)

下一篇:JS常见问题之为什么点击弹出的i总是最后一个(javascript常见问题)

  • 加计扣除减免税额怎么计算
  • 一般计税方法适用于500万
  • 房产公司售楼部装修费入什么会计科目
  • 个体户没有办税务登记,产生的房土两税
  • 民非企业增值税减免账务处理
  • 仓库缺货怎么处理
  • 转贴现视为贷款银行如何进行账务处理?
  • 专项维修资金的,由县级
  • 银行贷款利息支出汇算清缴需要调整吗
  • 企业所得税税收优惠方式有哪些
  • 现代服务促销服务费的经营范围
  • 增值税税控盘服务费可以每年都抵扣吗
  • 对方承担税费怎么做会计分录
  • 小规模减征额哪些项目
  • 股权转让流程详解
  • 对方公司税务注销了发票没有开给我怎么办
  • 银行余额不平怎么快速找原因
  • 劳务派遣公司增值税税率
  • 小型微利企业应纳税所得额300万
  • 退回的企业所得税如何在报表中显示
  • 印花税退款分录
  • 农村合作社补贴政策
  • 给客户购买礼品怎么记账
  • 购买机器设备配件账务处理
  • 如何办理存款证明
  • 净资产利润比率计算公式
  • 会计档案的保管期限是从什么算起
  • 房屋出租预收租金房产税纳税义务发生时间
  • 4500监控
  • PHP:ignore_user_abort()的用法_misc函数
  • 关闭非系统进程
  • thinkphp多数据库连接
  • 试用期人员工资财务记账
  • 保洁劳务派遣合同
  • uniapp scroll-view 上下滑动
  • api接口长什么样
  • 关于公司预支工资制度
  • 研发费用税前加计扣除金额怎么算
  • 进项不认证有什么风险
  • 开了银行对公账户要多久
  • 受托支付转给个人账户需要交税吗为什么
  • 一个合同里面服务怎么写
  • 2022-8-29 javaweb 第一天 servlet/tomcat
  • 酒店周转材料怎么摊销
  • 固定资产折旧的账务处理
  • 投资现金流负值表示什么
  • 生育津贴到公司账户了多久给个人
  • 冲销上个月成本的会计分录
  • 增值税勾选统计后如何导出明细表
  • 名为股权转让实为房地产转让
  • 其他收益和其他综合收益属于什么科目
  • 定期定额户要交哪些税
  • 营业外收入是损益类账户吗
  • 企业净资产如何算
  • 无进项发票开具销项发票
  • 营业外支出增加说明了什么
  • 支票小写金额可以涂改吗
  • 利润分配未分配利润怎么结转
  • 学校固定资产账记法
  • 辅助生产成本如何结转
  • win8.1补丁打不上
  • 科普知识手抄报简单又漂亮
  • windows vista(service pack1)
  • mac电脑怎么安装ie浏览器
  • hyper怎么用
  • mac怎么打出@符号
  • vim进阶教程
  • macbook外接多个显示器
  • win7系统禁止更新
  • win10插上耳机后电脑还是外放如何解决
  • GLWallpaperService分析一
  • php九宫格
  • linux sleep 2
  • shell 算数计算
  • node.js express中app.param的用法详解
  • javascript面向对象吗
  • 江苏电子票据
  • 税务稽查的后果
  • ca证书怎么删除
  • 武汉市江汉区财政局这个单位的公务员待遇怎么样?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设