var a=function和function a有啥区别

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了var a=function和function a有啥区别相关的知识,希望对你有一定的参考价值。

一、调用顺序不同

1、var a=function:匿名函数的定义方法,若是在定义之前调用了,系统会报错。

2、function a:该方法的定义是全局性的,就算在调用之后定义,系统也不会报错。

二、初始化不同

1、var a=function:只用运行到这个方法时才能对变量a进行初始化,若是没有对变量a初始化,则会报错。此时,a代表后面匿名函数的返回值。

2、function a:系统在执行到该方法时再去找该方法的定义位置进行初始化。


三、特点不同

1、var a=function:在javascript中,方法被当作一个类来处理,这中定义方式下,a即带表了这个方法的类,也就是这个方法本身。

2、function a:若是在该方法中,返回值为数组、方法、或是别的类,那么a不在表示该方法,而是表示返回的新类了。


参考资料来源:百度百科-Function函数

参考资料来源:百度百科-Function

参考技术A //代码一:
a(1);    //执行这个会报错
var a = function(index)
    alert(index);

a(2);    //执行这个不会报错

//代码二:
a(1);    //执行这个不会报错
function a(index)
    alert(index);

a(2);    //执行这个不会报错

原因:JavaScript 函数和变量声明的“提前”(hoist)行为。

区别一:代码一,加载js 代码之后 a 被 “提前",但是 function 里面的具体内容不会被提前。就是在调用    的时候就会去初始化 function 里面的代码块。代码二:加载的时候就 “提前”了。

//代码一: js 作用域污染
function a()  //function statement
  return '1';

alert(a()); // alerts '3'
function a() 
  return '3';


//代码二:
var a= function()  // function expression
  return '1';
;
alert(a()); // alerts '3'
a= function() 
  return '1';
;

强烈推荐看下 :

http://www.zhihu.com/question/19878052

关于new Function使用

一直对Function()一知半解,今日就Function()的使用做一下总结

一、函数实际是功能完整的对象,用Fucntion()直接创建函数。

语法规则:
    var 函数名 = new Function( arg1, arg2, arg3, ..., argN, body );
    解释:
    Function 构造函数所有的参数都是字符串类型的,body是生成函数的函数体。

实例:求多个参数的和

var fnSum = new Function( 
                \'var total = 0,args = arguments;for (var i = 0; i < args.length; i++ ) {total += args[ i ];}return total;\' );
            var res = fnSum(4,5,6);
            alert ( res );
View Code

注意:以上代码不允许有空格

对以上写法加以改进

第一种写法(传统):将字符串分割

var fnSum = new Function(
                \'var total = 0, \' +
                \'    args = arguments;\' + 
                \'for ( var i = 0; i < args.length; i++ ) { \' +
                \'    total += args[ i ]; \' +
                \'} \' +
                \'return total; \'
            );
            var res = fnSum( 1,2,3,4 );
            alert ( res );//10
View Code

第二种写法:吸收了MVC思想

<script id="engin">             
                 /*var total = 0, 
                    args = arguments, 
                    len = args.length;
                for ( var i = 0; i < len; i++ ) {
                    total += args[ i ];
                }
                return total;*/             
        </script>
        <script>
            var getBody = function ( id ) {
            var script = document.getElementById( id );
            var body = script.innerHTML.replace(\'/*\', \'\').replace(\'*/\', \'\');        
            script.parentNode.removeChild( script );
            return body;
        }
            onload = function () {                
                var fnSum = new Function( getBody( \'engin\' ) );                
                var res = fnSum( 1, 2, 3 );            
                alert( res );    //6
            };        
View Code

二、Function 和 eval 都可以实现字符串执行代码在实际开发中, 如果考虑效率可以直接使用 eval,但是考虑安全性则建议使用 Function

var str = \'{ name: "jim" }\';
eval( \'var o = \' + str )
//var o = eval( \'(\' + str + \')\' ); 等同于上句
console.log(o);//Object {name: "jim"}


 

eval( \'var a = 10;\' );  // eval 会污染全局变量
   eval 等价于 var a = 10;//全局变量

    mdn:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/eval

eval()是一个顶级函数并且跟任何对象无关。

eval()的参数是一个字符串。如果字符串表示了一个表达式,eval()会对表达式求值。如果参数表示了一个或多个JavaScript声明, 那么eval()会执行声明。不要调用eval()来为算数表达式求值; JavaScript 会自动为算数表达式求值。

如果要将算数表达式构造成为一个字符串,你可以用eval()在随后对其求值。比如,你有一个变量 x ,你可以通过一个字符串表达式来对涉及x的表达式延迟求值,将 "3 * x + 2",当作变量,通过在脚本中调用eval(),随后求值。

如果参数不是字符串,eval()将会将参数原封不动的返回。在下面的例子中,字符串构造器是指定的,eval()返回了字符串对象而不是对字符串求值。

eval() 是一个危险的函数, 它可以像拥有调用者的权力一样调用代码。如果你使用了字符串来运行eval(),那么你的代码可能被恶意方(不怀好意的人)影响, 通过在使用方的机器上使用恶意代码,可能让你失去在网页或者扩展程序上的权限 

 在JS中将JSON的字符串解析成JSON对象格式,一般有三种方式:


1.一种为使用eval()函数。

var str = \'{ "name": "yy", "gender": "girl" }\'; 
var obj = eval(\'(\'+str+\')\');
console.log(obj)//Object {name: "yy", gender: "girl"}

 

2. 使用Function对象来进行返回解析。

var str = \'{ "name": "yy", "gender": "girl" }\'; 
var obj = (new Function(\'\',\'return\'+str))();
console.log(obj);//Object {name: "yy", gender: "girl"}

 

3.使用JSON.parse()

var str = \'{ "name": "yy", "gender": "girl" }\'; 
var obj = JSON.parse(str);
console.log(obj);//Object {name: "yy", gender: "girl"}

 

 

 

 

 

 

以上是关于var a=function和function a有啥区别的主要内容,如果未能解决你的问题,请参考以下文章

js作用域理解 function(){} var

js中var的变量和function的函数名重名时的执行结果

JavaScript中的var functionName = function() vs function functionName()

function和var的区别

var和function定义方法的区别

JavaScript中var变量引用function与直接声明function