JavaScript学习笔记——2.函数

1.定义

  函数是一个完成“指定功能”且“命名”的代码段

  函数只有通过名称“调用”

2.基本格式

  function test(形参){
    ...
    return 值; //停止执行
  }
  test(实参);

  test()有括号为调用,在任何位置都可调用,包括自身(递归)

  test不加括号为函数自身,可当做变量使用

  所以:

  var test=function(形参){
    ...
  }
  test(实参);

3.参数处理

  “有形无实”的处理:

  function test(a,b){
    a = a?a:1; //未定义的undefined当做false进行判断
    b = b?b:2;
  }
  test(); //不传入参数,也可以有默认参数

  “无形有实”的处理:

  function test(){
    arguments //即为传入参数的数组
    arguments.length
    arguments[0]
  }
  test(1,2,3,4);

4.callback(回调函数)

  function b (){
    alert(‘a‘);
  }

  function a (cb){
    alert(‘hello world!‘);
    (cb && typeof(cb) === ‘function‘) && cb();
  }

  a(b);

5.系统函数

  说明:

  js是基于对象的,所有的函数创建后都自动添加给了window对象

  所以:

  function test(){
    ...
  }
  test(); //可调用
  window.test() //也可调用

  可直接使用的函数有window及Global对象(不需要加window.或global.):

  parseInt() //将字符串转化为整数,为割舍(第一个字符不能为非数字)

  parseFloat() //将字符串转换为浮点数

  isNaN() //判断是否为“非数字”,不是数字返回true,是数字返回false

  eval() //解析字符串作为程序并执行;相当于解析器

作者:@zhnoah
出处:http://www.cnblogs.com/zhnoah/
本文版权归本人和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连 
接,否则保留追究法律责任的权利。

时间: 2025-01-01 08:51:42

JavaScript学习笔记——2.函数的相关文章

javascript学习笔记--迭代函数

概要 这里的迭代函数指的是对数组对象的操作方法,js数组共有五个迭代函数:every.fifter.forEach.map.some. 1.every every方法,返回值为Boolean类型,true表示数组中所有元素都满足条件,false表示数组中至少有一个不满足条件,代码如下: 1 var numbers = [1,2,3,4,5,4,3,2,1]; 2 numbers.every(function(item,index,array){ return item > 2; }) 3 输出:

【JavaScript学习笔记】函数和数组

一.函数 一个函数应该只返回一种类型的值. 函数中有一个默认的数组变量arguments,存储着传入函数的所有参数. 为了使用函数参数方便,建议给参数起个名字. function fun1(obj, name, value){ console.log(arguments); console.log(obj); console.log(name); console.log(value); }fun1({'id':12}, 'username', '张三'); 二.数组 2.1.定义方式 var a

Javascript学习笔记(函数---再次学习)

1.函数的定义 2.函数的递归调用 3.闭包 1.函数的定义有两种: 第一种:函数声明 function functionName(arg0,arg1,arg2){ //函数体 } 函数声明,一个重要特征是函数声明提升,即在执行代码之前会先读取函数声明. 第二种:使用函数表达式 var functionName = function(arg0,arg1,arg2){ //函数体 }; 函数表达式与其他表达式一样,在使用前必须先赋值. 两种创建方式的区别:函数声明的方式创建函数会使函数声明提升.

JavaScript学习笔记【3】数组、函数、服务器端JavaScript概述

笔记来自<JavaScript权威指南(第六版)> 包含的内容: 数组 函数 服务器端JavaScript概述 数组 数组是动态的:根据需要它们会增长或缩减,并且在创建数组时无须声明一个固定的大小或在数组大小变化时无须重新分配空间. 数组可能是稀疏的:索引不一定要连续的,它们之间可以有空缺. 通常,数组的实现是经过优化的,用数字索引来访问数组元素一般来说比访问常规的对象属性要快很多. 数组继承自Array.prototype中的属性,它定义了一套丰富的数组操作方法. 如果省略数组直接量中的某个

javascript学习笔记---ECMAScript语法(引用类型)

引用类型通常叫做类(class). 本教程会讨论大量的 ECMAScript 预定义引用类型. 引用类型 引用类型通常叫做类(class),也就是说,遇到引用值,所处理的就是对象. 本教程会讨论大量的 ECMAScript 预定义引用类型. 从现在起,将重点讨论与已经讨论过的原始类型紧密相关的引用类型. 注意:从传统意义上来说,ECMAScript 并不真正具有类.事实上,除了说明不存在类,在 ECMA-262 中根本没有出现"类"这个词.ECMAScript 定义了"对象定

javascript学习笔记---ECMAScriptECMAScript 对象----定义类或对象

使用预定义对象只是面向对象语言的能力的一部分,它真正强大之处在于能够创建自己专用的类和对象. ECMAScript 拥有很多创建对象或类的方法. 原始的方式 因为对象的属性可以在对象创建后动态定义(后绑定),类似下面的代码: var oCar = new Object; oCar.color = "blue"; oCar.doors = 4; oCar.mpg = 25; oCar.showColor = function() { alert(this.color); };不过这里有一

javascript学习笔记---ECMAScriptECMAScript 对象----修改对象

通过使用 ECMAScript,不仅可以创建对象,还可以修改已有对象的行为. prototype 属性不仅可以定义构造函数的属性和方法,还可以为本地对象添加属性和方法. 创建新方法 通过已有的方法创建新方法Number.prototype.toHexString = function() { return this.toString(16); }; 在此环境中,关键字 this 指向 Number 的实例,因此可完全访问 Number 的所有方法.有了这段代码,可实现下面的操作: var iNu

javascript学习笔记---ECMAScript语法(变量)

变量声明关键字var: var i = 1: var t = "asd"; var test1 = "hi", test2 = "hello"; 声明变量不一定要初始化, var i;//ok 另一方面在使用变量前若未加关键字var,则此变量为全局变量(此特性需特别记住). 变量名字: 变量名需要遵守两条简单的规则: 第一个字符必须是字母.下划线(_)或美元符号($) 余下的字符可以是下划线.美元符号或任何字母或数字字符 命名变量规则: Came

JavaScript学习笔记【2】表达式和运算符、语句、对象

笔记来自<JavaScript权威指南(第六版)> 包含的内容: 表达式和运算符 语句 对象 表达式和运算符 数组直接量中的列表逗号之间的元素可以省略,这时省略的空位会填充值undefined.元素列表末尾可以留下单个逗号,这时并不会创建一个新的值为undefined元素. 属性访问表达式,.identifier的写法只适用于要访问的属性名称是合法的标识符,并且需要知道要访问的属性的名字.如果属性名称是一个保留字或者包含空格和标识符,或是一个数字(对于数组来说),则必须使用方括号的写法.当属性