javascript 函数声明在if语句里面

问题描述

javascript 函数声明在if语句里面
var x = 1;
if(function f(){},x=f){
 }
 console.log(x);

为什么在执行if语句的时候,会报f is not defined的错误.

解决方案

[觉得对弱类型语言还钻了下牛角尖]
条件判断里不应该进行有作用域的定义,
发现只能定义全局变量
if(i=3,x=i) //good
if(var i=3,x=i) //bad
你的例子,我给你改一下就正确了,只是发现一点规律,具体原因,我不确定

var x = 1;
if(gF = function f(){return 3;},x=gF){ }
console.log(x());//3

more:

if(window.test = function useless(){return 3;},x=window.test())//good
{
console.log(test());//3
//console.log(useless());//bad
}

解决方案二:

你直接用x=f,但是你f都没有定义啊

时间: 2024-10-31 22:10:46

javascript 函数声明在if语句里面的相关文章

JavaScript函数声明与表达式小结

函数声明与表达式 函数是JavaScript中的一等对象,这意味着可以把函数像其它值一样传递. 一个常见的用法是把匿名函数作为回调函数传递对异步函数中. 函数声明 function foo() {} 上面的方法会在执行前被 解析(hoisted),因此它存在于当前上下文的任意一个地方, 即使在函数定义体的上面被调用也是对的. foo(); // 正常运行,因为foo在代码运行前已经被创建 function foo() {} 函数赋值表达式 var foo = function() {}; 这个例

Javascript函数声明与函数表达式的区别

在定义函数时,我们一般使用下面这两种方法: Js中的函数声明是指下面的形式:       function functionName(){    }    这样的方式来声明一个函数,而函数表达式则是类似表达式那样来声明一个函数,如: var functionName = function(){  }    可能很多朋友在看到这两一种写法时会产生疑惑,这两种写法差不多,在应用中貌似也都是可行的,那他们有什么差别呢? 使用函数声明定义: function  sum (a, b) {     retu

javascript 函数声明与函数表达式的区别介绍_javascript技巧

还是一样,先上代码: 复制代码 代码如下: <script> var f = function g() { return 1; }; if (false) { f = function g(){ return 2; }; } alert(g()); // 2 </script> 把这段代码扔到IE 6 里面和chorme里面是完全不同的两种效果. 这里输出2 是在ie6里面的效果,如果在chorme会出现g没有定义. 这也算是JScript的bug吧. 在这里很明显,这里的只是定义

JavaScript函数声明和函数表达式

JavaScript中的函数不同于其他的语言,每个函数都是作为一个对象被维护和运行的.通过函数对象的性质,可以很方便的将一个函数赋值给一个变量或者将函数作为参数传递.在继续讲述之前,先看一下函数的使用语法:  代码如下 复制代码 function func1(-){-} var func2=function(-){-}; var func3=function func4(-){-}; var func5=new Function(); 另外还有一种自执行函数表达式,主要用于创建一个新的作用域,在

JavaScript中函数表达式和函数声明及函数声明与函数表达式的不同_javascript技巧

函数表达式和函数声明 在ECMAScript中,创建函数的最常用的两个方法是函数表达式和函数声明,两者期间的区别是有点晕,因为ECMA规范只明确了一点:函数声明必须带有标示符(Identifier)(就是大家常说的函数名称),而函数表达式则可以省略这个标示符: 函数声明: function 函数名称 (参数:可选){ 函数体 } 函数表达式: function 函数名称(可选)(参数:可选){ 函数体 } 所以,可以看出,如果不声明函数名称,它肯定是表达式,可如果声明了函数名称的话,如何判断是函

Javascript中函数声明与函数表达式的区别

Js中的函数声明是指下面的形式: function functionName(){ } 这样的方式来声明一个函数,而函数表达式则是类似表达式那样来声明一个函数,如: var functionName = function(){ } 可能很多朋友在看到这两一种写法时会产生疑惑,这两种写法差不多,在应用中貌似也都是可行的,那他们有什么差别呢? 事实上,js的解析器对函数声明与函数表达式并不是一视同仁地对待的.对于函数声明,js解析器会优先读取,确保在所有代码执行之前声明已经被解析,而函数表达式,如同

详解JavaScript中的函数声明和函数表达式_java

JavaScript 中需要创建函数的话,有两种方法:函数声明.函数表达式,各自写法如下: // 方法一:函数声明 function foo() {} // 方法二:函数表达式 var foo = function () {}; 另外还有一种自执行函数表达式,主要用于创建一个新的作用域,在此作用域内声明的变量不会和其它作用域内的变量冲突或混淆,大多是以匿名函数方式存在,且立即自动执行: (function () { // var x = ... })(); 此种自执行函数表达式归类于以上两种方法

javascript中声明函数的方法及调用函数的返回值_基础知识

<html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> <!--js中声明函数的方法--> <script type="text/javascript"> //因为javascript是弱类型的语言,所以参数不需要加类型.函数的也不需要像c#那样要求所以路径都需要有返回值(这个不像c#语言,而且c#的方法也不需要在方法

全面了解函数声明与函数表达式、变量提升_javascript技巧

函数的声明方式 在定义一个函数的时候通常有两种声明方式: foo(){}; // 函数声明 var foo = function(){}; // 函数表达式 不同之处 1.函数表达式后面加括号可以直接执行 2.函数声明会提前预解析 预解析 让我们先看一个例子: foo(); // 函数声明 foo_later(); // foo_later is not a function function foo(){ console.log('函数声明'); } var foo_later = funct