函数当成类看当成匿名对象看,都是跟java吻合的,只有当成函数看(函数自己可以执行)跟java区别在这里。

function fact(){}
var F = fact ;
函数名是函数对象的地址,是地址就有内存区域,执行就是地址名()小括号,var f = new F(),f就不是指向函数F的地址了,他是F类的对象,他的地址里面是对象,不仅仅是一个函数。 function fact(num){
if(num <=1) return 1 ;
else return num*fact(num-1), //fact只是一个变量名存的是函数地址,
}
alert(fact(5));
var F = fact ;
fact = null;//进一步证明了fact只是一个变量名存的是函数地址,
alert(F(5)); //报错,fact不是一个函数
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script type=text/javascript charset=utf-8>
//形参无类型
function test(a ,b){
alert(a+b);
alert(111);
return a+b;
}
var c = test(10 , 20);
//函数当成类看当成匿名对象看,都是跟java吻合的,只有当成函数看(函数自己可以执行)跟java区别在这里。 alert(c);
alert(typeof test); //函数也是一种数据类型 (function类型) function test1(aa){
aa();
}
function test2(){
alert('执行啦');
}
test1(function(){ alert('我也执行啦!')}); // 在js中函数是可以嵌套定义的 (尽量不要这样去定义)
function test3(){
function test4(){
alert('我是test4!');
}
test4();//函数调用
}
test3();//函数调用
</script>
</head>
<body>
</body>
</html>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script type=text/javascript charset=utf-8>
// 3种方式定义函数
// 1 function语句式
function test1(){
alert('我是test1');
}
test1(); // 2函数的直接量 ECMAScript
var test2 = function(){
alert('我是test2');
}
test2(); // 3function构造函数式
var test3 = new Function("a" , "b" ,"return a+b;");//函数参数,函数体
alert(test3(10,20));//30 //效率对比
var d1 = new Date();
var t1 = d1.getTime();
for(var i =0 ; i <100000;i++){
function test1(){;} //function语句的形式,最开始函数解析一次放在内存中,多次调用用同一个,
var test2 = new Function();//函数调用一次就解析一次,执行完就销毁了,多次调用多次解析,
}
var d2 = new Date();
var t2 = d2.getTime();
alert(t2 -t1); test1();//可以运行
function test1(){
alert('1111');
}
alert(test2); //undefined
test2();//test2 is not a function
var test2 = function(){
alert('2222');
} /* 4 2 3 3 5 6
{
var f : 未定义
f : function f(){return 4;}
}
{
var f : new Function("return 2;"); ---> function(){return 3;} --->
new Function("return 5"); ---> function(){return 6 ;}
}
*/
function f(){return 1;}
alert(f()); //返回值为4
var f = new Function("return 2;");
alert(f()); //返回值为2
var f = function(){return 3;}
alert(f()); //返回值为3
function f(){return 4;}
alert(f()); //返回值为3
var f = new Function("return 5");
alert(f()); //返回值为5
var f = function(){return 6 ;}
alert(f()); //返回值为6 //函数作用域的概念
var k = 1 ;
function t1(){
var k = 2 ; //局部变量 k
function test(){return k ;} //function语句,k = 2
var test = function(){ return k}; //函数直接量,k = 2
var test = new Function('return k;'); // 构造函数的方式,k = 1
alert(test());
}
t1();
</script>
</head>
<body>
</body>
</html>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script type=text/javascript charset=utf-8>
//js中 函数的参数: 形参 实参
function test(a,b){
alert(test.length); // 形参个数
//内部就是用一个数组去接受函数的实际参数,arguments 对象 可以访问函数的实际参数,只能在函数的内部访问和使用
alert(arguments.length);
alert(arguments[0]);
alert(arguments[1]);
if(arguments.callee.length == arguments.length){
return a+b;
} else {
return '参数不正确!';
}
//arguments对象 用的最多的 还是做递归操作
//arguments.callee 指的是函数本身。
}
alert(test(10,20)); // 30 function fact(num){
if(num <=1) return 1 ;
else return num*arguments.callee(num-1); //num*fact(num-1),fact只是一个变量名存的是函数地址,
}
alert(fact(5));
var F = fact ;//函数名是函数对象的地址,是地址就有内存区域,执行就是地址名()小括号,var f = new F(),f就不是指向函数F的地址了,他是F类的对象,他的地址里面是对象,不仅仅是一个函数。
fact = null;//就不能写num*fact(num-1),进一步证明了fact只是一个变量名存的是函数地址,
alert(F(5));
</script>
</head>
<body>
</body>
</html>

js08--函数1的更多相关文章

  1. js---08函数 定时器

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  2. Python 小而美的函数

    python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况   any any(iterable) ...

  3. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  4. JavaScript权威指南 - 函数

    函数本身就是一段JavaScript代码,定义一次但可能被调用任意次.如果函数挂载在一个对象上,作为对象的一个属性,通常这种函数被称作对象的方法.用于初始化一个新创建的对象的函数被称作构造函数. 相对 ...

  5. C++对C的函数拓展

    一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...

  6. 菜鸟Python学习笔记第一天:关于一些函数库的使用

    2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...

  7. javascript中的this与函数讲解

    前言 javascript中没有块级作用域(es6以前),javascript中作用域分为函数作用域和全局作用域.并且,大家可以认为全局作用域其实就是Window函数的函数作用域,我们编写的js代码, ...

  8. 复杂的 Hash 函数组合有意义吗?

    很久以前看到一篇文章,讲某个大网站储存用户口令时,会经过十分复杂的处理.怎么个复杂记不得了,大概就是先 Hash,结果加上一些特殊字符再 Hash,结果再加上些字符.再倒序.再怎么怎么的.再 Hash ...

  9. JS核心系列:浅谈函数的作用域

    一.作用域(scope) 所谓作用域就是:变量在声明它们的函数体以及这个函数体嵌套的任意函数体内都是有定义的. function scope(){ var foo = "global&quo ...

  10. C++中的时间函数

    C++获取时间函数众多,何时该用什么函数,拿到的是什么时间?该怎么用?很多人都会混淆. 本文是本人经历了几款游戏客户端和服务器开发后,对游戏中时间获取的一点总结. 最早学习游戏客户端时,为了获取最精确 ...

随机推荐

  1. HNU 12961 BitTorrent DP

    题意: 你在网上下载东西,一个文件存储在一段或者多段里面,问怎么选择能在规定的流量内下载最多的文件数量.每段的大小一样. 思路: 习惯了做答案保存在DP数组里的题,做这种答案保存在下标里的题,转不过弯 ...

  2. 【转】 基于C#.NET的高端智能化网络爬虫 2

    [转] 基于C#.NET的高端智能化网络爬虫2 本篇故事的起因是携程旅游网的一位技术经理,豪言壮举的扬言要通过他的超高智商,完美碾压爬虫开发人员,作为一个业余的爬虫开发爱好者,这样的言论我当然不能置之 ...

  3. 【LeetCode-面试算法经典-Java实现】【032-Longest Valid Parentheses(最长有效括号)】

    [032-Longest Valid Parentheses(最长有效括号)] [LeetCode-面试算法经典-Java实现][全部题目文件夹索引] 原题 Given a string contai ...

  4. 81.node.js前端html时页面格式错乱解决办法

    var http = require("http"); var url = require("url"); var fs = require("fs& ...

  5. spring xml配置文件根元素(文件头文件)说明

    <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...

  6. Codeforces 344D Alternating Current 简单使用栈

    Description Mad scientist Mike has just finished constructing a new device to search for extraterres ...

  7. OpenJDK源码研究笔记(十):枚举的高级用法,枚举实现接口,竟是别有洞天

    在研究OpenJDK,Java编译器javac源码的过程中,发现以下代码. 顿时发现枚举类竟然也有如此"高端大气上档次"的用法. 沙场点兵(用法源码) com.sun.tools. ...

  8. @MapperScan 和 @ComponentScan 区别

    1.首先@MapperScan和@ComponentScan都是扫描包 2.@ComponentScan是组件扫描注解,用来扫描@Controller  @Service  @Repository这类 ...

  9. visualvm监控tomcat

    https://my.oschina.net/weidedong/blog/787203

  10. JSONArray和JSONObject的简单使用

    一.为什么要使用JSONArray和JSONObject 1.后台 -->前台 能够把java对象和集合转化成json字符串格式,这样在前台的ajax方法中能够直接转化成json对象使用 ,从后 ...