JavaScript(2):函数
<!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):函数的更多相关文章
- JavaScript中函数函数的定义与变量的声明<基础知识一>
1.JavaScript中函数的三种构造方式 a.function createFun(){ } b.var createFun=function (){ } c.var createFun=new ...
- 理解 JavaScript 回调函数并使用
JavaScript中,函数是一等(first-class)对象:也就是说,函数是 Object 类型并且可以像其他一等对象(String,Array,Number等)一样使用.它们可以"保 ...
- 5种 JavaScript 调用函数的方法
一次又一次的,我发现,那些有bug的Javascript代码是由于没有真正理解Javascript函数是如何工作而导致的(顺便说一下,许多那样的代码是我写的).JavaScript拥有函数式编程的特性 ...
- javascript escape()函数和unescape()函数
javascript escape()函数和unescape()函数 escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串. 语法: escape(string) stri ...
- JavaScript调用函数的方法
摘要:这篇文章详细的介绍了Javascript中各种函数调用的方法及其原理,对于理解JavaScript的函数有很大的帮助! 一次又一次的,我发现,那些有bug的Javascript代码是由于没有真正 ...
- Javascript常用方法函数收集(二)
Javascript常用方法函数收集(二) 31.判断是否Touch屏幕 function isTouchScreen(){ return (('ontouchstart' in window) || ...
- javascript工具函数
第一部分 JavaScript工具函数 转义特殊字符为html实体 HtmlEncode: function(str){ return str.replace(/&/g, '&') ...
- [转]javascript eval函数解析json数据时为什加上圆括号eval("("+data+")")
javascript eval函数解析json数据时为什么 加上圆括号?为什么要 eval这里要添加 “("("+data+")");//”呢? 原因在于: ...
- javascript篇-----函数作用域,函数作用域链和声明提前
在一些类似C语言的编程语言中,花括号内的每一段代码都具有各自的作用域,而且变量在声明它们的代码段之外是不可见的(也就是我们不能在代码段外直接访问代码段内声明的变量),我们称之为块级作用域,然而,不同于 ...
- JavaScript 常用函数总结
javascript函数: ·常规函数 ·数组函数 ·日期函数 ·数学函数 ·字符串函数 .cookie函数 1.常规函数 javascript常规函数包括以下9个函数: (1)alert ...
随机推荐
- shodan使用
简介 与谷歌不同的是,Shodan不是在网上搜索网址,而是直接进入互联网的背后通道.Shodan可以说是一款“黑暗”谷歌,一刻不停的在寻找着所有和互联网关联的服务器.摄像头.打印机.路由器等等.每个月 ...
- java合并数组的几种方法,stream流合并数组
一.实例代码 package cc.ash; import org.apache.commons.lang3.ArrayUtils; import java.lang.reflect.Array; i ...
- pssh一个微量级自动化工具
一.pssh简介 pssh是一个python编写可以在多台服务器上执行命令的工具,也可实现文件复制.pssh需要通过ssh的key验证来管理主机,其不能很好的支持密码验证.用过epel源的pssh包来 ...
- 爱搞事情的webpack
webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler). 当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency g ...
- BZOJ 3926: [Zjoi2015]诸神眷顾的幻想乡(广义后缀自动机 多串)
因为任何一条路径都可以看做某两个叶子节点之间路径的一部分,然后分别把20个叶节点当作根,把整棵树看作trie树,那么一条路径就能看作是从根到某个点这一条路的后缀,构建SAM就能维护不同子串的个数了. ...
- 让create-react-app支持sass,less
用create-react-app 创建的项目不支持sass和less,需要手动配置 npm install node-sass sass-loader --save 然后在config/webpac ...
- 灰度图像--频域滤波 傅里叶变换之离散时间傅里叶变换(DTFT)
学习DIP第22天 转载请标明本文出处:http://blog.csdn.net/tonyshengtan,欢迎大家转载,发现博客被某些论坛转载后,图像无法正常显示,无法正常表达本人观点,对此表示很不 ...
- LVS集群之NAT模式
集群的分类: (1)HA:高可用集群,有叫双机热备 原理:两台机器A.B,正常是A提供服务,当A机宕机或者服务有问题时,会切换到B机继续提供服务常用的高了永软件:heartbeat和keepalive ...
- vue + ts Vuex篇
Vuex对Typescript的支持,仍十分薄弱,官方库只是添加了一些.d.ts声明文件,并没有像vue 2.5这样内置支持. 第三方衍生库 vuex-typescript, vuex-ts-deco ...
- TCP输入 之 tcp_prequeue
在未开启tcp_low_latency的情况下,软中断将skb送上来,加入到prequeue中,然后 在未启用tcp_low_latency且有用户进程在读取数据的情况下,skb入队到prequeue ...