javascript面向对象一:函数
Arguments对象
<script type="text/javascript">
/*
Arguments对象:
* 在Java中存在函数的重载现象.
* 节省了函数的命名空间.
* 降低了编码难度.
* 性能较好.
* 在javascript中也能实现函数的重载?
* 不存在函数的重载.
* 定义多个同名的函数时,只有最后一个是起作用.
* Arguments对象的作用:
* 在javascript中,函数定义没有任何参数,调用该函数时可以传递任意参数.
* Arguments对象是数组对象.
* Arguments对象的length属性:获取函数的实参的个数.
* 利用Arguments对象特性,实现模拟函数的重载的效果.
*/
function add(a, b){
return a + b;
}
function add(a, b, c){
return a + b + c ;
}
alert(add(1,2)); //output NaN:表示当前值不是一个数字.isNan():返回Boolean,判断是否不是数字.
alert(add(1,2,3)) //output 6
function fn(){
alert(arguments.length);
}
fn(); //output 0
fn("a"); //output 1
fn("a","b"); //output 2
fn("a","b","c"); //output 3
function add2(){
if(arguments.length==2){
return arguments[0] + arguments[1];
}else if(arguments.length==3){
return arguments[0] + arguments[1] + arguments[2];
}
}
alert(add2(1,2)); //output 3
alert(add2(1,2,3)); //output 6
</script>
变量的作用域
/*
javascript中的变量作用域:
* 全局变量:全局域+函数域.
* 局部变量:当前函数域.
*/
var a = "a";
function fn(){
var b = "b";
alert(a); //output a
alert(b); //output b
}
fn();
alert(a); //output a
alert(b); //未输出
/*
在javascript定义变量可以不使用"var".
在定义局部变量时,没有使用"var":
* javascript会自动将没有var的局部变量,定义为全局变量
需要注意的是:
* 依旧不建议大家这样编写代码.
*/
var a = "a";
function fn(){
b = "b";
alert(a); //output a
alert(b); //output b
}
fn();
alert(a); //output a
alert(b); //output b
/*
解读代码:
* 定义一个全局变量a,并初始化为a.
* 定义一个函数fn(),但该函数没有被调用(函数中的代码是不执行的)
* 该函数中,定义了局部变量a,但没有初始化.
* 调用函数fn(),执行该函数中的代码.
* 第一次打印变量a,打印的是局部变量a.
* 第二次打印变量a,打印的是局部变量a.
javascript的特点:
* javascript一次性定义代码中所有变量.
* 全局变量与局部变量同名时,在函数域中:只能访问局部变量.
*/
var a = "a";
function fn(){
alert(a); //output undefined
var a = "b";
alert(a); //output b
}
fn();
alert(a); //output a
特殊函数
/*
匿名函数:没有名的函数
* 定义函数的一种方式:var 函数名 = function(){}
* 将匿名函数作为参数,传递给另一个函数.
* 将匿名函数用来完成一次性任务.
回调函数:
* 将一个函数作为参数传递给另一个函数,而作为参数的函数,就叫做回调函数.
* 将一个匿名函数作为参数传递给另一个函数,而作为参数的匿名函数,就叫做匿名回调函数.
*/
var one = function(){return 1;}
var two = function(){return 2;}
// 形参a, b是一个函数.
function fn(a, b){
return a() + b();
}
alert(fn(one, two)); //output 3
// 将以上代码进行改写
alert(fn(function(){return 1;}, function(){return 2;})); //output 3
/*
什么是一次性:只能使用一次的.
* 一次性函数:
* 用来完成页面初始化工作的函数(不严格)
* 定义即调用的函数(不严格)
* 语法规定只能使用一次的.
* 自调函数:
* 第一个小括号:封装函数
* 第二个小括号:调用函数
*/
(
function(){
alert("this is javascript.");
}
)();
(
function(str){
alert(str + "this is javascript.");
}
)("hello ");
/*
内部(私有)函数:
* 与Java中的内部类很相似.
* 好处:保证了私有性.
* 与局部变量的作用是一样的.
*/
function fn(){
var a = "a";
function n(){
var b = "b";
alert(a);
alert(b);
}
n();
}
fn();//a b
/*
(了解)返回函数的函数(内部函数的一种特殊用法)
* 定义一个函数,可以执行两个逻辑体
*/
function fn(){
var a = "a";
return function(){
return a;
}
}
alert(fn()); //output function(){return a;}
alert(fn()()); //output a
预定义函数
javascript面向对象一:函数的更多相关文章
- JavaScript面向对象(01)--函数
在JavaScript中,函数和对象有区别,也有联系, 首先函数是一个对象,但是和对象存在一些区别如下: 1,不论在java还是js中,如果把一个对象赋值给另一个变量,那么,后者会指向前者对象所在的内 ...
- JavaScript面向对象之函数构造器的理解
1,在使用函数创建类时,函数本身也被称为该类的构造器,该类的构造器方法,该类的构造方法,该类的构造函数等等. 2,注意构造器方法是没有返回值的,当创建该类的实例时,必须调用该类的构造方法. 3,获取构 ...
- javascript面向对象属性函数用法(defineProperty与getOwnPropertyDescriptor)
defineProperty用于设置一个对象的属性描述符,属性描述符有4个:[[Configurable]], [[Enumerable]], [[Writable]],[[Value]] 当一个属性 ...
- 02.JavaScript 面向对象精要--函数
在JavaScript中,函数其实也是对象.是函数不同于其他对象的特点是:函数存在一个被称为[[Call]]的内部属性.[[Call]]属性是函数独有的,表明该对象可以被执行.ECMAScript 定 ...
- JavaScript面向对象—基本数据类型和引用数据类型的区别和变量及作用域(函数和变量)
基本类型和引用类型的值 ECMAScript 变量可能包含两种不同的数据类型的值:基本类型值和引用类型值. 基本类型值指的是那些保存在栈内存中的简单数据段,即这种值完全保存在内存中的一个位置. 而引用 ...
- JavaScript面向对象编程指南(三) 函数
第3章 函数 3.1 什么是函数 函数:本质是一种代码的分组形式.函数的声明如下: <script type="text/javascript"> /*函数的声明组成: ...
- JavaScript学习笔记(三)——this、原型、javascript面向对象
一.this 在JavaScript中this表示:谁调用它,this就是谁. JavaScript是由对象组成的,一切皆为对象,万物皆为对象.this是一个动态的对象,根据调用的对象不同而发生变化, ...
- JavaScript面向对象
理解对象 对象这个词如雷贯耳,同样出名的一句话:XXX语言中一切皆为对象! 对象究竟是什么?什么叫面向对象编程? 对象(object),台湾译作物件,是面向对象(Object Oriented)中的术 ...
- JavaScript学习总结(三)——this、原型、javascript面向对象
一.this 在JavaScript中this表示:谁调用它,this就是谁. JavaScript是由对象组成的,一切皆为对象,万物皆为对象.this是一个动态的对象,根据调用的对象不同而发生变化, ...
- javascript面向对象系列第三篇——实现继承的3种形式
× 目录 [1]原型继承 [2]伪类继承 [3]组合继承 前面的话 学习如何创建对象是理解面向对象编程的第一步,第二步是理解继承.本文是javascript面向对象系列第三篇——实现继承的3种形式 [ ...
随机推荐
- DataGridView直接导出EXCEL
1public void DataToExcel(DataGridView m_DataView) { SaveFileDialog kk = new SaveFileDialog(); kk.Tit ...
- 关于cin.getline和cin.get
<C++ Primer Plus(第六版)> P124 第8题 #include <iostream> using namespace std; struct Pizza ...
- HALF<水题>
题意: 找出n/d=0.5的所有数.输入:test,x(代表n的位数,1<=x<=4).并且n和d的每一个位数不能有重复,也不能是0. 输入: 1 1 输出: the form 1/2 = ...
- 【转】Java 内部类种类及使用解析
Java 内部类种类及使用解析 内部类Inner Class 将相关的类组织在一起,从而降低了命名空间的混乱. 一个内部类可以定义在另一个类里,可以定义在函数里,甚至可以作为一个表达式的一部分. Ja ...
- Keychain 浅析
什么是Keychain? 根据苹果的介绍,iOS设备中的Keychain是一个安全的存储容器,可以用来为不同应用保存敏感信息比如用户名,密码,网络密码,认证令牌.苹果自己用keychain来保存Wi- ...
- 《割绳子》《蜡笔物理学》《Contre Jour》《顽皮鳄鱼爱洗澡》等游戏用Box2D引擎实现物理部分的方法(转)
从最热门游戏排行榜和flash游戏网站上,你能看到什么?许多2D游戏都有非常出色的物理学和美术设计.现在我们要学习那些游戏使用了什么物理学以及如何用Box2D制作它们. 除了知道是“什么”,更重要的是 ...
- js框架——angular.js(5)
1. 3种过滤方式 <html> <head> <meta charset='utf-8'> <script src="js/angular.js& ...
- 8633 回文划分(dp)
8633 回文划分 该题有题解 时间限制:1000MS 内存限制:1000K提交次数:169 通过次数:63 题型: 编程题 语言: G++;GCC Description 我们说一个字符串是回 ...
- mapreduce 顺序组合
import java.io.IOException;import java.util.StringTokenizer; import org.apache.hadoop.conf.Configura ...
- action参数绑定
thinkPHP支持操作方法的参数绑定功能 action参数通过直接绑定URL中的变量作为操作方法的参数,可以简化方法的定义甚至路由的简析. 原理是把URL的中参数(不包括模块,控制器和操作名)和控制 ...