<!DOCTYPE html>
<html>
<body>
<p>JavaScript 函数</p>
<script>
// 函数声明
function myFunction(a, b) { return a * b;}
console.log(myFunction(2, 6));
// 函数表达式(匿名函数)
var demo1 = function(a, b) {return a * b;};
console.log(demo1(2, 5));
// Function()构造函数 [F大写!]
var demo2 = new Function("a", "b", "return a * b");
console.log(demo2(2, 4));
// 自调用函数(匿名自我调用的函数) [添加两对括号!]
(function() {
console.log("Call myself.");
})(); // 函数是对象
// 使用 typeof 操作符判断函数类型将返回 "function"
console.log(typeof demo1 == 'function');
// toString() 方法将函数作为一个字符串返回
console.log(demo1.toString()); // Arguments对象
// [例1]获取最大值
function myMax() {
var i, max = arguments[0];
if(arguments.length < 2) return max;
for(i = 1; i < arguments.length; i++){
if(arguments[i] > max) max = arguments[i];
}
return max;
}
console.log(myMax(1, 3, 9, 5, 7));
// [例2]统计所有数值的和
function mySum() {
var i, sum = 0;
for(i = 0; i < arguments.length; i++) sum += (arguments[i] = arguments[i] || 0);
return sum;
}
var undef;
console.log(mySum(1, 3, 5, 7, 9, null, undef)); // 函数作为方法调用
var myObject = {
firstName: "Frank",
lastName: "Liu",
fullName: function() { return this.firstName + " " + this.lastName; }
}
console.log(myObject.fullName()); // 构造函数调用函数
function demo3(arg1, arg2) {
this.firstName = arg1;
this.lastName = arg2;
}
var demo4 = new demo3("Frank", "Liu");
console.log(demo4.firstName); // call()和apply()是预定义的函数方法。 两个方法可用于调用函数,两个方法的第一个参数必须是对象本身
// call则作为call的参数传入(从第二个参数开始)
var demo5 = myMax.call(demo5, 3, 1, 5 ,2);
console.log(demo5);
// apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入
var demo6 = myMax.apply(demo6, [3, 1, 6 ,2]);
console.log(demo6); // JavaScript闭包
// 函数的特别之处在于可以创建一个独立的作用域,最内层的函数使用了counter变量,所以counter不会被销毁
var add = (function() {
var counter = 0;
return function() { return counter += 1; };
})();
console.log("Loop1: " + add()); // 1
console.log("Loop2: " + add()); // 2
console.log("Loop3: " + add()); // 3
</script>
</body>
</html>

JavaScript(2):函数的更多相关文章

  1. JavaScript中函数函数的定义与变量的声明<基础知识一>

    1.JavaScript中函数的三种构造方式 a.function createFun(){ } b.var createFun=function (){ } c.var createFun=new ...

  2. 理解 JavaScript 回调函数并使用

    JavaScript中,函数是一等(first-class)对象:也就是说,函数是 Object 类型并且可以像其他一等对象(String,Array,Number等)一样使用.它们可以"保 ...

  3. 5种 JavaScript 调用函数的方法

    一次又一次的,我发现,那些有bug的Javascript代码是由于没有真正理解Javascript函数是如何工作而导致的(顺便说一下,许多那样的代码是我写的).JavaScript拥有函数式编程的特性 ...

  4. javascript escape()函数和unescape()函数

    javascript escape()函数和unescape()函数 escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串. 语法: escape(string) stri ...

  5. JavaScript调用函数的方法

    摘要:这篇文章详细的介绍了Javascript中各种函数调用的方法及其原理,对于理解JavaScript的函数有很大的帮助! 一次又一次的,我发现,那些有bug的Javascript代码是由于没有真正 ...

  6. Javascript常用方法函数收集(二)

    Javascript常用方法函数收集(二) 31.判断是否Touch屏幕 function isTouchScreen(){ return (('ontouchstart' in window) || ...

  7. javascript工具函数

    第一部分 JavaScript工具函数 转义特殊字符为html实体   HtmlEncode: function(str){ return str.replace(/&/g, '&') ...

  8. [转]javascript eval函数解析json数据时为什加上圆括号eval("("+data+")")

    javascript eval函数解析json数据时为什么 加上圆括号?为什么要 eval这里要添加 “("("+data+")");//”呢?   原因在于: ...

  9. javascript篇-----函数作用域,函数作用域链和声明提前

    在一些类似C语言的编程语言中,花括号内的每一段代码都具有各自的作用域,而且变量在声明它们的代码段之外是不可见的(也就是我们不能在代码段外直接访问代码段内声明的变量),我们称之为块级作用域,然而,不同于 ...

  10. JavaScript 常用函数总结

    javascript函数:  ·常规函数  ·数组函数  ·日期函数  ·数学函数  ·字符串函数 .cookie函数 1.常规函数 javascript常规函数包括以下9个函数:  (1)alert ...

随机推荐

  1. 关于first-class object的解释

    关于first-class object的解释 定义,什么是编程语言的第一等公民? In computer science, a programming language is said to hav ...

  2. js栈和堆的区别

    一.  堆(heap)和栈(stack) 栈(stack)会自动分配内存空间,会自动释放.堆(heap)动态分配的内存,大小不定也不会自动释放. 二.  基本类型和引用类型 基本类型:简单的数据段,存 ...

  3. Dom修改元素样式

    提纲:我们可以通过js来修改元素的大小,颜色,位置等样式 1.element.style                         行内样式的操作 2.element.className    ...

  4. java poi 生成多个sheet

    我的需求是:在一个表格中生成多个sheet,每个sheet的名称动态指定,每个sheet内的内容动态指定.生成的文件名动态指定. 工具类: package test; import java.io.O ...

  5. css3小动画:鼠标hover后text-decoration的动画

    实现效果 具体实现 利用css3 ::after或者::before伪元素实现.html代码 <a class="abstract-title" href="/ar ...

  6. 使用js拆分带参数的URL,将参数分离出来

    url中的内容www.XXXX.com?content=123; 一下为js内容,包装在一个init方法中. init(); function init(){ var theRequest = new ...

  7. 设置Portainer管理Docker并且开启https(简单方法)

    1. 序言 Portainer是一个十分好用的docker图形化管理界面,可以很方便的查看容器状态,错误log等等. 2. 安装 安装portainer是十分简单的,只需要执行docker pull ...

  8. cookie生命周期expires 时间过期,但是cookie没有被浏览器清理的问题

    cookie生命周期expires 时间过期,但是cookie没有被浏览器清理的问题 今天用nodejs起了一个web服务,使用art-template模板引擎渲染出来的页面,在这里我设置了一个coo ...

  9. vue 运行脚手架报错

    报错: You are using the runtime-only build of Vue where the template compiler is not available. Either ...

  10. 7 vi 编辑器

    1.vim编辑器的工作模式 命令模式,插入模式,可视化模式,扩展命令模式. 2.命令模式 2.1.光标定位 hjkl:小键盘上下左右移动 0 $:行头.行尾 gg G:第一行.最后一行 30G:进入第 ...