Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 788|回复: 0

javascript入门(函数)

[复制链接]

该用户从未签到

发表于 2011-10-28 13:56:29 | 显示全部楼层 |阅读模式
准备写下一系列javascript入门的文章,一方面算是自己对javascript知识的稳固,一方面也希望对初学javascript的朋友有所帮助。javascript的基本类型和语法其实跟java是非常相似的,对于javaeye的朋友我想都清楚,今天就从javascript的函数写起:

1、js函数声明:   
Js代码
   
function fun1(arg){   
alert(arg+",This is my first js function !"); }   
var fun2 = new Function("arg","alert(arg);");   
//尽管可用Function构造函数创建函数,但最好不要使用它,因为它比第一种传统方式定义函数要慢得多!   
//不过所有函数都应该看作为是Function类的实例! fun1("Jesen"); fun2("Jesen");   


function fun1(arg){
alert(arg+",This is my first js function !"); }
var fun2 = new Function("arg","alert(arg);");
//尽管可用Function构造函数创建函数,但最好不要使用它,因为它比第一种传统方式定义函数要慢得多!
//不过所有函数都应该看作为是Function类的实例! fun1("Jesen"); fun2("Jesen");


2、和java不同,js是无重载的:
  
Js代码
   
function fun1(arg){   
alert(arg+100); }   
function fun1(arg,arg2){   
alert(arg+10); }   
//第二个fun1将覆盖第一个的定义,在下面讲到的arguments中可以解决重载问题。   
fun1(10);   


function fun1(arg){
alert(arg+100); }
function fun1(arg,arg2){
alert(arg+10); }
//第二个fun1将覆盖第一个的定义,在下面讲到的arguments中可以解决重载问题。
fun1(10);





3、arguments对象

   
Js代码
   
//arguments对象是传给函数的参数数组   
function fun1(){ alert(arguments.length); }   
fun1(); fun1(2); fun1(2,3);   
//模拟函数重载   
function fun3(){   
if(arguments.length==1)   
{ alert(arguments[0]+10); }   
else{ alert(arguments[0]+arguments[1]); } }   
fun3(100); fun3(10,20);   


//arguments对象是传给函数的参数数组
function fun1(){ alert(arguments.length); }
fun1(); fun1(2); fun1(2,3);
//模拟函数重载
function fun3(){
if(arguments.length==1)
{ alert(arguments[0]+10); }
else{ alert(arguments[0]+arguments[1]); } }
fun3(100); fun3(10,20);





4、闭包

     对于闭包,理解的不是很透彻,也请了解的朋友解释下。

     有说函数内部使用全局变量就是一个简单的闭包的:

   
Js代码
   
var g_arg = "ok"; function fun1(){ alert(g_arg); }   
fun1();   


var g_arg = "ok"; function fun1(){ alert(g_arg); }
fun1();






    也有一种是函数外部调用函数内部变量的闭包:

  
Js代码
   
function a(){ var i=0; function b(){ alert(++i); } return b; }   
var c = a(); c(); c();   


function a(){ var i=0; function b(){ alert(++i); } return b; }
var c = a(); c(); c();






   不是很理解javascript中闭包的作用,大家可讨论下。

   

严格意义上讲任何一个function在执行时就构成一个闭包,闭包的实质是作用域。


普通的function,内部声明的变量在执行完会全被回收掉,这时闭包也被回收了,所以这种闭包对我们没有用处,他只是个作用域。

如果一个function的局部变量在执行时被生命周期更长的变量引用,那么这个function执行完时就不能回收掉这个局部变量,这个局部变量的生命周期超出了他的作用域,这时的作域也不能被回收掉,就形成了典型的闭包。

闭包的作用就是使局部变量拥有更大的生命周期,甚至全局的生命周期,这使得闭包可以保存function执行时的状态,特别是那种function中又返回一个function时,被返回的function就可以访问父function执行时的所有局部变量(典型的带状态函数)。因为JS中回收一个变量不是看作用域是否结束,而是看引用数。


5、匿名函数

     js实现匿名函数有三种方式:

     a、函数字面量:首先声明一个函数对象,然后执行它。
Js代码
(function(arg){ alert(arg); } ) (1);   


     (function(arg){ alert(arg); } ) (1);



   b、优先表达式:由于Javascript执行表达式是从圆括号里面到外面,所以可以用圆括号强制执行声明的函数。
Js代码
( function(arg){ alert(arg); } (2) );   


    ( function(arg){ alert(arg); } (2) );









   c、Void操作符:用void操作符去执行一个没有用圆括号包围的一个单独操作数。
Js代码
void function(arg){ alert(arg); }(3)   


    void function(arg){ alert(arg); }(3)



    我们一般通常用第一种方法,在扩展jquery的时候我们也经常会用到这种匿名函数的写法:

Js代码
     
  
(function($) { $.fn.pluginName = function() { // Our plugin implementation code goes here. }; })(jQuery);   

  

(function($) { $.fn.pluginName = function() { // Our plugin implementation code goes here. }; })(jQuery);




     上面定义了一个jQuery函数,形参是$,函数定义完成之后,把jQuery这个实参传递进去.立即调用执行。这样的好处是,我们在写jQuery插件时,也可以使用$这个别名,而不会与prototype引起冲突.
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2025-1-8 13:27 , Processed in 0.666205 second(s), 45 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表