好程序不是写给computer的,而是写给human的。遇到复杂功能,应该想着把它简化、组件化,把小功能封装成小组件,小功能块可以任意的组合得到千变万化的复杂功能。function就可以帮助我们把功能进行封装。那什么是封装呢。要我说,只要把具体实现给打包,对外提供调用接口那就是封装,方法也好、类也好就做了这些事。
javascript中的function可以用来创建方法、也可以用来创建类,实际上我们可以认为是用function来模拟出的类(说到类一般都会要去了解闭包的知识)。还是先看一下方法吧。
javascript函数分为有名函数、匿名函数和在匿名函数基础上延伸出来的立即执行函数。
普通函数就是用function直接声明的有名函数。
<SPAN class=kwrd>function</SPAN> Hello() {
alert(<span class="str">"hello , everybody!"</span>);
};
Hello();
<SPAN class=kwrd>function</SPAN> SayHelloTo(somebody) {
alert(<span class="str">"hello , "</span> + somebody + <span class="str">"!"</span>);
};
SayHelloTo(<SPAN class=str>"张三"</SPAN>);
上面分别创建了Hello和SayHelloTo方法。Hello不带有参数,直接通过Hello()来完成调用。SayHelloTo方法带有一个参数,向谁问候时需要知道是在问候谁。在调用SayHelloTo(“张三”)时要传入参数。这些代码和java、C#都没有什么太大区别。在方法重载上却有较大改变,javascript本身并不支持什么重载,一个方法名就对应一个方法。如果强制的写出多个同名方法,其实会出现先写的方法被覆盖掉的情况。
<SPAN class=kwrd>function</SPAN> Hello() {
alert(<span class="str">"hello , everybody!"</span>);
};
Hello();
<SPAN class=kwrd>function</SPAN> Hello(somebody) {
alert(<span class="str">"hello , "</span> + somebody + <span class="str">"!"</span>);
};
Hello(<SPAN class=str>"张三"</SPAN>);


第一个Hello方法被覆盖掉,执行时直接调用Hello()则认为调用第二个Hello方法但没有传递参数值,所以弹出了undefined信息。调用Hello(“张三”)时很正常的完成执行。其实javascript也可以用一些直白的方式来完成重载。学过C#的人都会知道有个params关键字,通过它可以实现向方法传递不定个数的参数。我们可以通过对参数的信息做手动的判断也可以模拟出类似重载的效果。而在javascript中根本就不需要什么params关键字,就可以很自然的实现任意个数参数的传递。function中有个arguments属性,可以把它看成一个数组,它按传递进来的参数的顺序来保存所有的参数。也就是说我们在定义方法时可以不声明参数名。
<SPAN class=kwrd>function</SPAN> ShowArguments() {
<span class="kwrd">var</span> args = <span class="str">""</span>;
<SPAN class=kwrd>for</SPAN> (<SPAN class=kwrd>var</SPAN> i = 0; i < arguments.length; i++) {
args += arguments[i] + <span class="str">","</span>;
};
alert(args.substr(0, args.length - 1));
};
ShowArguments(1, 2, 3, 4, 5, 6, 7);
<SPAN class=kwrd>function</SPAN> Hello() {
<span class="kwrd">if</span> (arguments.length == 0) {
alert(<SPAN class=str>"hello , everybody!"</SPAN>);
}
<SPAN class=kwrd>else</SPAN> {
alert(<span class="str">"hello , "</span> + arguments[0] + <span class="str">"!"</span>);
};
};
Hello();
Hello(<SPAN class=str>"张三"</SPAN>);
基于参数个数不同的重载。
<SPAN class=kwrd>function</SPAN> Increase(arg) {
<span class="kwrd">if</span> (<span class="kwrd">typeof</span> arg == <span class="str">"undefined"</span>) {
alert(<SPAN class=str>"请输入参数"</SPAN>);
}
<SPAN class=kwrd>if</SPAN> (<SPAN class=kwrd>typeof</SPAN> arg == <SPAN class=str>"string"</SPAN>) {
alert(String.fromCharCode(arg.charCodeAt(0) + 1));
}
<span class="kwrd">if</span> (<span class="kwrd">typeof</span> arg == <span class="str">"number"</span>) {
alert(arg + 1);
}
};
Increase();
Increase(<span class="str">"a"</span>);
Increase(1);
函数除了有名函数之外也可以是匿名函数,匿名函数就是没有名子的函数,不论函数有名还是没有名子,都是一个完整的函数对象。匿名函数还是用function来声明,但不用为它指定名称。其它的方面,比如参数等等和有名函数没什么区别。
<SPAN class=kwrd>function</SPAN>() {
……
};
匿名函数一般可以满足临时的函数需求,不需要有变量对其进行引用(有名的函数可以认为是有变量引用的函数)。比如需要一个函数做为值对象做为参数传入方法、需要编程的方式为对象添加事件,用匿名函数都可以很好的完成。当然你也可以单独声明变量来引用某个匿名函数对象,这和普通有名函数就没什么区别了。
<SPAN class=kwrd>function</SPAN> Each(array, fun) {
<span class="kwrd">for</span> (<span class="kwrd">var</span> i = 0; i <pre class='brush:php;toolbar:false;'> fun(array[i]);
};
};
<span class="kwrd">var</span> nums = [1, 2, 3, 4, 5, 6, 7];
Each(nums, <SPAN class=kwrd>function</SPAN>(arg) {
alert(arg);
});
上面代码执行,依次输出数组中的元素。
<SPAN class=rem>//在窗体加载时,在标题上显示当前时间</SPAN>
window.onload = <span class="kwrd">function</span>() {
document.title = <SPAN class=kwrd>new</SPAN> Date().toString();
};
<span class="rem">//也可以将匿名方法传入定时器中</span>
setInterval(<SPAN class=kwrd>function</SPAN>() {
document.title = <span class="kwrd">new</span> Date().toString();
}, 1000);
使用匿名函数绑定事件和进行定时操作。
<SPAN class=kwrd>var</SPAN> Hello = <SPAN class=kwrd>function</SPAN>() {
alert(<span class="str">"hello , everybody!"</span>);
};
如果将匿名函数赋给变量,那和有名的普通函数就没区别了。但不管是变量引用还是普通地有名函数,这样的函数在内存上都持久的占有一定资源。有时候我们只想执行一次大不必使用有引用的函数,直接执行匿名函数可能是最好的选择。把匿名函数包起来,加个括号执行,一切ok,这就是由匿名函数延伸出来的立即执行函数。
(<SPAN class=kwrd>function</SPAN>() {
alert(<span class="str">"hello , everybody!"</span>);
})();
(<SPAN class=kwrd>function</SPAN>(somebody) {
alert(<span class="str">"hello , "</span> + somebody + <span class="str">"!"</span>);
})(<SPAN class=str>"张三"</SPAN>);
立即执行函数在做事件绑定,设置回调函数等方面往往会有意想不到的效果,可以解决诸如对象引用等问题。
<SPAN class=kwrd>var</SPAN> student = {
Name: <span class="str">"张三"</span>,
Age: 20,
Introduce: <span class="kwrd">function</span>() {
alert(<SPAN class=str>"我叫"</SPAN> + <SPAN class=kwrd>this</SPAN>.Name + <SPAN class=str>",今年"</SPAN> + <SPAN class=kwrd>this</SPAN>.Age + <SPAN class=str>"岁了!"</SPAN>);
} };
window.onload = (<SPAN class=kwrd>function</SPAN>(obj) { <SPAN class=kwrd>return</SPAN> <SPAN class=kwrd>function</SPAN>() { obj.Introduce(); }; })(student);
因为javascript中函数的这些特点加之它的对象的特征,我们还可以写出一些有functional意味的程序出来。其实javascript中function真的是老大。
<SPAN class=kwrd>function</SPAN> Sum(fun, x) {
<span class="kwrd">if</span> (x <pre class='brush:php;toolbar:false;'> <SPAN class=kwrd>return</SPAN> 0;
<span class="kwrd">return</span> fun(x) + Sum(fun, x - 1);
};
alert(Sum(<SPAN class=kwrd>function</SPAN>(i) { <SPAN class=kwrd>return</SPAN> i * i; }, 100));
下面这又是什么呢?是方法吗?是类吗?
<SPAN class=kwrd>function</SPAN> Point() {
};
先啰嗦到这,下次再看看类。

如何使用Go语言实现面向对象的事件驱动编程引言:面向对象的编程范式被广泛应用于软件开发中,而事件驱动编程是一种常见的编程模式,它通过事件的触发和处理来实现程序的流程控制。本文将介绍如何使用Go语言实现面向对象的事件驱动编程,并提供代码示例。一、事件驱动编程的概念事件驱动编程是一种基于事件和消息的编程模式,它将程序的流程控制转移到事件的触发和处理上。在事件驱动

解析PHP面向对象编程中的享元模式在面向对象编程中,设计模式是一种常用的软件设计方法,它可以提高代码的可读性、可维护性和可扩展性。享元模式(Flyweightpattern)是设计模式中的一种,它通过共享对象来降低内存的开销。本文将探讨如何在PHP中使用享元模式来提高程序性能。什么是享元模式?享元模式是一种结构型设计模式,它的目的是在不同对象之间共享相同的

go语言既不是面向对象,也不是面向过程,因为Golang并没有明显的倾向,而是更倾向于让编程者去考虑该怎么去用它,也许它的特色就是灵活,编程者可以用它实现面向对象,但它本身不支持面向对象的语义。

python是面向对象的。Python语言在设计之初,就定位为一门面向对象的编程语言,“Python中一切皆对象”就是对Pytho 这门编程语言的完美诠释。类和对象是Python的重要特征,相比其它面向对象语言,Python很容易就可以创建出一个类和对象;同时,Python也支持面向对象的三大特征:封装、继承和多态。

PHP作为一种广泛使用的编程语言,已成为构建动态网站和网络应用程序的首选语言之一。其中,面向对象编程(OOP)的概念和技术越来越受到开发者的欢迎和推崇。本篇文章将为读者提供PHP面向对象编程的入门指南,介绍OOP的基本概念,语法和应用。什么是面向对象编程(OOP)?面向对象编程(Object-OrientedProgramming,简称OOP),是一种编程

如何使用Go语言实现面向对象的数据库访问引言:随着互联网的发展,大量的数据需要被存储和访问,数据库成为了现代应用开发中的重要组成部分。而作为一门现代化、高效性能的编程语言,Go语言很适合用来处理数据库操作。而本文将重点讨论如何使用Go语言实现面向对象的数据库访问。一、数据库访问的基本概念在开始讨论如何使用Go语言实现面向对象的数据库访问之前,我们先来了解一下

Python作为一种高级编程语言,在众多编程语言中占有举足轻重的地位。它的语法简单易学,拥有各种强大的编程库,被广泛应用于数据处理、机器学习、网络编程等领域。而其中最重要的一点便是Python完美支持面向对象编程,本文将重点阐述Python中的面向对象编程。一、面向对象编程的基本概念在面向对象的编程语言中,数据和方法被封装在对象的内部。这使得对象能够独立地进

面向对象是软件开发方法,一种编程范式。是一种将面向对象的思想应用于软件开发过程并指导开发活动的系统方法。这是一种基于“对象”概念的方法论。对象是由数据和允许的操作组成的包,它与目标实体有直接的对应关系。对象类定义了一组具有类似属性的对象。面向对象是基于对象的概念,以对象为中心,以类和继承为构建机制,认识、理解和描绘客观世界,设计和构建相应的软件系统。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver CS6
视觉化网页开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Atom编辑器mac版下载
最流行的的开源编辑器