- 浏览: 1181899 次
- 性别:
- 来自: 北京
-
文章分类
最新评论
-
zhizhen23:
LZ 提供的链接地址失效了
重写的isPlainObject方法 -
LovingBaby:
LovingBaby 写道function fun() {}f ...
读jq之二(两种扩展) -
LovingBaby:
说的很清楚!jQuery作者为了实现简洁调用的苦心!高超的编程 ...
读jq之一(jq对象的组成) -
hard_ly:
...
将伪数组转换成数组 -
zlxzlxzlxzlxzlx:
这不能算是任意进制之间的转换,例如二十六进制、十二进制又该如何 ...
用递归实现十进制数转换N进制
相信两种方式大家都用过,但未必所有人都知道其 区别,内部原理。
// 方式1 function func1(x,y){ // your code } // 方式2 var func2 = function(x,y){ // your code }
方式1 是典型的函数声明(Function declarations)。
方式2 是函数表达式(Function expressions),将一个匿名函数赋值给一个变量。或者说方式2中创建了一个具有形参为x,y的匿名函数,然后把该匿名函数赋值给变量func2。
其主要区别在于:
1, 函数声明需显示的指定函数名,这里是func1;函数表达式则使用匿名函数
2, 方式1在代码执行之前(解释期)被加载到作用域中,方式2则需在代码执行时(运行期)加载
一个简单示例就明白了它们在使用上的区别
alert(func1); // --> func1源码 alert(func2); // --> undefined // 方式1 function func1(x,y){ // your code } // 方式2 var func2 = function(x,y){ // your code }
可以看到,第一次弹出的是func1的源码,第二次却是undefined。即采用方式1(函数声明)定义函数,可以在该函数代码之上使用它,采用方式2(函数表达式)定义函数则不能在其定义前使用,只能在其定义后使用。
其内部涉及到 执行上下文(Execution context)及 激活对象(Activation object)。想更深了解的请阅读EcmaScript 5文档。
最近发现越来越多的人喜欢使用方式2定义函数,尤其在嵌套函数中。如单纯的定义一个函数个人还是习惯方式1。
评论
12 楼
mimang2007110
2010-10-28
这两种定义方式哪种效率更好一些呢????
11 楼
select*from爱
2010-10-15
代码顺序执行原则,如果在函数前调用该函数,可能会引起逻辑混乱
我一般采用第二种方式 在定义某些全局类的时候用第一种
我一般采用第二种方式 在定义某些全局类的时候用第一种
10 楼
ccyingfu
2010-10-15
看情况,看习惯,看类的设计方式。
9 楼
西门吹牛
2010-10-12
soni 写道
可以这样简单理解,js解释器在执行js代码的时候分为2个阶段。
首先,加载所有函数声明,初始化var声明的变量。
然后,顺序执行代码。
所以,无论函数在那里声明,都会最先加载,保证在运行时函数是有效的。是不是匿名函数没啥区别。
初始化var声明的变量,只是表明变量存在,变量的赋值在执行时进行。
但是,实际上的执行过程比这个要复杂些,其中还涉及到变量的范围,作用域链等细节。
首先,加载所有函数声明,初始化var声明的变量。
然后,顺序执行代码。
所以,无论函数在那里声明,都会最先加载,保证在运行时函数是有效的。是不是匿名函数没啥区别。
初始化var声明的变量,只是表明变量存在,变量的赋值在执行时进行。
但是,实际上的执行过程比这个要复杂些,其中还涉及到变量的范围,作用域链等细节。
多谢解答,谢谢
![](/images/smiles/icon_idea.gif)
8 楼
soni
2010-10-12
可以这样简单理解,js解释器在执行js代码的时候分为2个阶段。
首先,加载所有函数声明,初始化var声明的变量。
然后,顺序执行代码。
所以,无论函数在那里声明,都会最先加载,保证在运行时函数是有效的。是不是匿名函数没啥区别。
初始化var声明的变量,只是表明变量存在,变量的赋值在执行时进行。
但是,实际上的执行过程比这个要复杂些,其中还涉及到变量的范围,作用域链等细节。
首先,加载所有函数声明,初始化var声明的变量。
然后,顺序执行代码。
所以,无论函数在那里声明,都会最先加载,保证在运行时函数是有效的。是不是匿名函数没啥区别。
初始化var声明的变量,只是表明变量存在,变量的赋值在执行时进行。
但是,实际上的执行过程比这个要复杂些,其中还涉及到变量的范围,作用域链等细节。
7 楼
西门吹牛
2010-10-12
什么 解释期?什么运行期?难道js也有一个“编译”的过程?
解释期是不是可以理解为js运行环境的初始化,函数内var声明的变量会被归属给该函数,所以在声明之前调用不会报错?
什么是执行上下文(Execution context)? 激活对象(Activation object)?希望楼主不要抛出一个概念,又不做解释!我会很痛苦的
解释期是不是可以理解为js运行环境的初始化,函数内var声明的变量会被归属给该函数,所以在声明之前调用不会报错?
什么是执行上下文(Execution context)? 激活对象(Activation object)?希望楼主不要抛出一个概念,又不做解释!我会很痛苦的
6 楼
love_ai87
2010-10-12
markone 写道
楼主可以做另一个实验,更简单一些的实验:
function func() {
alert(v1);
}
func();
这时会抛出异常,因为从当前context一直找到global都没有这个对象。
而如果:
function func() {
alert(v1);
var v1 = 1;
}
这时候会弹出窗口undefined
这说明js引擎在构造函数context和activation object的时候(称为构建期),会事先检查var关键字并创建reference,只是这个reference的赋值是runtime的
而用function func() {}这种非匿名方式创建的函数,在构建期就会被加入活动对象中。
个人估计,这是为了闭包~
不错,楼主的命题虽小但是包含了许多语言特性。
function func() {
alert(v1);
}
func();
这时会抛出异常,因为从当前context一直找到global都没有这个对象。
而如果:
function func() {
alert(v1);
var v1 = 1;
}
这时候会弹出窗口undefined
这说明js引擎在构造函数context和activation object的时候(称为构建期),会事先检查var关键字并创建reference,只是这个reference的赋值是runtime的
而用function func() {}这种非匿名方式创建的函数,在构建期就会被加入活动对象中。
个人估计,这是为了闭包~
不错,楼主的命题虽小但是包含了许多语言特性。
你这例子前后都不一致,根本说明不了什么东西,在js里面,定义在函数里的局部变量,是在整个函数范围可以访问的,所以是可以在定义前访问的,和函数声明方式没关系
5 楼
markone
2010-10-11
个人推荐
如果函数要作为回调传给别的上下文,应该使用var func = function(){}这种方式
而如果函数要在当前上下文中作为private使用,则用function func(){}这种非匿名方式更好。
如果函数要作为回调传给别的上下文,应该使用var func = function(){}这种方式
而如果函数要在当前上下文中作为private使用,则用function func(){}这种非匿名方式更好。
4 楼
markone
2010-10-11
楼主可以做另一个实验,更简单一些的实验:
function func() {
alert(v1);
}
func();
这时会抛出异常,因为从当前context一直找到global都没有这个对象。
而如果:
function func() {
alert(v1);
var v1 = 1;
}
这时候会弹出窗口undefined
这说明js引擎在构造函数context和activation object的时候(称为构建期),会事先检查var关键字并创建reference,只是这个reference的赋值是runtime的
而用function func() {}这种非匿名方式创建的函数,在构建期就会被加入活动对象中。
个人估计,这是为了闭包~
不错,楼主的命题虽小但是包含了许多语言特性。
function func() {
alert(v1);
}
func();
这时会抛出异常,因为从当前context一直找到global都没有这个对象。
而如果:
function func() {
alert(v1);
var v1 = 1;
}
这时候会弹出窗口undefined
这说明js引擎在构造函数context和activation object的时候(称为构建期),会事先检查var关键字并创建reference,只是这个reference的赋值是runtime的
而用function func() {}这种非匿名方式创建的函数,在构建期就会被加入活动对象中。
个人估计,这是为了闭包~
不错,楼主的命题虽小但是包含了许多语言特性。
3 楼
mimang2007110
2010-10-11
这两种方法哪一种更好一些呢???
2 楼
doabit
2010-10-10
第二种方法和AS3里面的一样,定义成变量。可以像变量一样使用方法,,改变这个变量所对的方法。。反正我个人是这么理解的
1 楼
tang_123_
2010-10-10
第二种方法有什么优点吗?
发表评论
-
JavaScript获取图片的原始尺寸
2016-04-20 10:30 1697页面里的img元素,想要 ... -
JavaScript中奇葩的假值
2016-03-14 17:43 1268通常在以下语句结构中需要判断真假 if分支语句 whi ... -
世界上最短的数字判断代码
2016-03-14 16:21 1686我们知道JavaScript提供了typeof运算符,因此最 ... -
getBoundingClientRect在IE9/10里的bug
2015-01-12 08:30 1744getBoundingClientRect可以获得页面中某个 ... -
JavaScript中的直接量与初始器的区别
2014-11-08 06:09 1737很多代码优化及公司规范都会提到 写对象不应该 var ... -
JavaScript中的不可见数据类型
2014-11-02 11:08 1386JS提供了一些内置对象、函数和构造器供我们编程,如Math ... -
ES5严格模式
2014-10-08 18:20 1357严格模式(Strict mode)是由ECMA-262规范 ... -
JavaScript生成GUID的算法
2014-07-16 14:25 3085全局唯一标识符(GUID,Globally Unique ... -
JavaScript中点号“.”的多义性
2014-06-07 19:42 1736点号「.」在JavaScript中 ... -
冗余换性能-从Backbone的triggerEvents说开了去
2014-02-19 11:03 1042Backbone是一个优秀的前端MVC库,它的代码质量必定 ... -
JavaScript中delete操作符不能删除的对象
2013-11-27 13:21 1380ES3 中,delete在8.6.2.5及11.4.1有介 ... -
JavaScript中instanceof对于不同的构造器可能都返回true
2013-11-19 11:13 1302我们知道 instanceof 运算符用来检查对象是否为某 ... -
JavaScript里模拟sleep
2013-10-16 07:52 1621有几种方式,但都不完美 一、不断循环,直到达到指定时间 ... -
参数有中包含空格且使用Post提交时须将空格转换成加号
2013-10-14 08:07 5284jQuery的serialize模块中有个r20正则 ... -
JavaScript中“基本类型”之争
2013-10-04 20:58 1200前端面试中常被问到的问题之一就是“JavaScript的基本 ... -
ES3和ES5关于计算顺序的问题(ES5先计算函数ES3则是参数)
2013-09-13 23:35 1368从cmc那看到的,分享给园友。以下是一个怪异的代码,谁 ... -
一道关于"/g"笔试题
2013-07-26 07:13 1107正则里“g”表示全局(global)的意思,比如当替换字符串 ... -
JavaScript原型继承的陷阱
2013-05-27 20:51 1448JavaScript默认采用原型 ... -
JavaScript中__proto__与prototype的关系
2013-05-21 10:38 1514这里讨论下对象的内 ... -
JavaScript中__proto__与prototype的关系
2013-05-21 10:01 3这里讨论下对象的内 ...
相关推荐
在JavaScript中,函数可以以两种主要方式定义:声明式函数和函数表达式。此外,函数在JavaScript中也可被当作变量处理,可以被赋值、作为参数传递给其他函数。接下来我们将详细解释这些概念,并通过提供的代码示例来...
在JavaScript编程中,面向对象编程是处理复杂问题的一种常用方法。...混合方式则结合了构造函数和原型的优点,成为最灵活的一种定义类的方式。无论选择哪一种方式,都应结合项目的具体情况和开发者的编程风格来决定。
本指南将深入探讨JavaScript的高效编程和函数式编程这两个重要主题,帮助开发者提升技能,实现更优雅、更可维护的代码。 《Effective JavaScript(中文版).pdf》这本书是JavaScript编程的经典之作,它包含了68个具体...
这两种定义方式各有特点,并且在不同的上下文中有着不同的行为。 #### 函数声明(Function Declaration) 函数声明是定义一个命名函数的最常见方式。它由`function`关键字后跟函数名、参数列表以及函数体组成。...
JavaScript 函数的定义有两种方法:函数声明式和函数赋值式。 函数声明式(function declaration)是一种常用的定义函数的方法,语法为:`function fun_name () { }`,直接返回结果。这种方法可以在函数定义之前或...
本文将深入探讨JavaScript中两种常见函数使用方式的区别:嵌套函数和在函数内部调用外部函数,并通过具体示例来阐述它们之间的差异。 #### 二、嵌套函数概述 嵌套函数是指在一个函数内部定义另一个函数的情况。...
匿名函数可以使用两种方式创建。第一种方式是使用上面的定义方式,例如: ``` var square = function(x) { return 2 * x; } ``` 第二种方式是使用自执行匿名函数,例如: ``` (function(x, y) { alert(x + y); })...
JavaScript有两种作用域:全局作用域和函数作用域。在函数内部声明的变量仅在该函数内部可见。ES6引入了块级作用域,通过let和const关键字实现,但函数作用域仍然独立于块级作用域。 七、闭包 闭包是指函数可以访问...
JavaScript中的函数有两种主要类型:普通函数(也称为传统函数或函数表达式)和箭头函数。这两种函数在语法和行为上都有所不同,对于理解和编写JavaScript代码至关重要。 ### 普通函数 #### 1. 定义 普通函数通过`...
在JavaScript中,可以通过多种方式定义函数: 1. **声明式函数**(Function Declaration): ```javascript function func1() { // 函数体 } ``` 这是最常见的函数定义方式,其特点是可以在代码中任何地方...
在JavaScript中,定义函数主要有三种方式:函数关键字(function)语句定义、函数字面量(Function Literals)和Function()构造函数。函数字面量和Function()构造函数定义的函数可以没有名称,也就是我们说的匿名...
### JavaScript中实现trim函数的两种方法 在日常的前端开发工作中,我们经常需要对字符串进行操作,其中一种常见的需求就是去除字符串两端的空白字符。尽管现代JavaScript已经内置了`trim()`方法来帮助开发者轻松...
在 JavaScript 中,回调函数是一种常见的功能编程技术,被广泛应用于各种场景之中。本文旨在深入探讨回调函数的概念、工作原理以及如何在实际开发中应用它们。 #### 一、回调函数的定义与特点 **定义:** 回调函数...
这在递归函数中特别有用,可以提高性能。 八、函数式库 JavaScript有许多函数式编程库,如Ramda和Lodash的FP模式,它们提供了丰富的函数式工具,简化了编写函数式代码的过程。 九、惰性求值 虽然JavaScript本身不...
创建对象有两种主要方式:构造函数和对象字面量。 **构造函数** ```javascript const person = new Object(); person.name = "张三"; ``` **对象字面量** ```javascript const person = { name: "张三", age: 25...
函数有两种声明方式:函数声明和函数表达式。前者具有提升(hoisting)特性,后者则不会。例如: ```javascript // 函数声明 hello(); // 正常执行,无语法错误 function hello() { console.log('Hello!'); } // ...
JavaScript 函数是编程语言的核心部分,它是一种组织代码的方式,使得代码可以被多次重用,降低了程序的复杂性。在JavaScript中,函数是一段可执行的代码块,它能够接收参数,执行特定任务,并可能返回结果。以下是...
为了在JavaScript中调用C++函数,我们需要一个中间层来桥接这两种语言。这个中间层通常是一个库或插件,它在JavaScript环境中暴露C++函数,使得JavaScript能够调用它们。 在MFC框架下,我们可以使用ActiveX控件或...
它们与其他语言中的函数定义方式有着很大的区别。 函数对象(Function Object) 函数对象可以用 `function` 关键字定义一个函数,并为每个函数指定一个函数名,通过函数名来进行调用。在 JavaScript 解释执行时,...
通常我们会看到以下两种定义函数的方式: 代码如下:// 函数语句function fn(str){ console.log(str);}; // 表达式定义var fnx=function(str){ console.log(str+ ‘ from fnx’);};以前都是凭借自己手指的感觉...