js36---函数嵌套
<!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" />
<script type=text/javascript charset=utf-8>
function F(){
alert("函数F")
var a= 1;
return function(){
this.name = a++;
alert(this.name);
}
}
var f1 = F();// 函数F
f1();//1
f1();//2 var f2 = F();// 函数F
f2();//1
f2();//2 var f3 = F();// 函数F
var f31 = new f3();//1
alert(f31.name);//1
var f32 = new f3();//2
alert(f32.name);//2
//------------------------------------------------
var f4 = new F();// 函数F
f4();//1
f4();//2 var f5 = new F();// 函数F
f5();//1
f5();//2 var f6 = new F();//函数F
var f61 = new f6();//1
alert(f61.name);//1
var f62 = new f6();//2
alert(f62.name);//2
</script>
</head>
<body>
</body>
</html>
外层函数既可以当成函数看也可以当成类看。内部返回的既可以当成函数看也可以当成类看。
var getXHR = function(){
             alert(2);
             getXHR = function(){
                alert(1);
             }
        }
        getXHR();//2
        getXHR();//1
        getXHR();//1
        var getXHR = function(){
             var a  = 1;
             getXHR = function(){
                return 2;
             }
            return a;
        }
        alert(getXHR());//1
        alert(getXHR());//2
        alert(getXHR());//2
var getXHR = function(){
             var a  = 1;
             getXHR = function(){
                alert(2);
                return 2;     //只是return了内部函数
             }
            getXHR();
            return a;
        }
        alert(getXHR());//2   1
        var getXHR = function(){
             var a  = 1;
             getXHR = function(){
                alert(2);
                return 2;
             }
            (function(){ //不能这么写
                alert(3);
                return 2;
             })();  // is not a function
            getXHR();
            return a;
        }
        alert(getXHR());//2  1
function F(){}
    var f = function(){}
    Function.prototype.method =function(name,fn){
        alert(1);
    }
    f.method();//1
    F.method();//1
function F(){}
    var f = function(){}
    Function.prototype.method =function(name,fn){
        this.prototype[name] = fn;
        return this;
    }
    f.method("a",function(){alert("a");});//1
    F.method("b",function(){alert("b");});//1
    //f.a();//f.a is not a function
    f.prototype.a();//a
    //F.b();//F.b is not a function
    F.prototype.b()//b
    new F().b();//b
js36---函数嵌套的更多相关文章
- JavaScript ES7 中使用 async/await 解决回调函数嵌套问题
		原文链接:http://aisk.me/using-async-await-to-avoid-callback-hell/ JavaScript 中最蛋疼的事情莫过于回调函数嵌套问题.以往在浏览器中, ... 
- python之函数嵌套
		python很多特性与JavaScript是相似甚至相同的: 1. 无类型 2. 函数亦对象 .... 自然: python也允许函数嵌套, 这与JavaScript中函数闭包的作用一样.... 
- 不使用回调函数的ajax请求实现(async和await简化回调函数嵌套)
		在常规的服务器端程序设计中, 比如说爬虫程序, 发送http请求的过程会使整个执行过程阻塞,直到http请求响应完成代码才会继续执行, 以php为例子 $url = "http://www. ... 
- Oracle之分组函数嵌套以及表连接
		--1 数据环境准备 scott 用户下面的emp,dept表 --2 要求 :求平均工资最高的部门编号,部门名称,部门平均工资 select d.deptno,d.dname,e.salfrom(s ... 
- nodejs批量导入数据eventproxy(回调函数嵌套解决方案)使用实例
		回调函数嵌套解决方案——eventProxy API地址:https://github.com/JacksonTian/eventproxy 1.安装eventproxy 执行npm install ... 
- python全栈开发-Day9 函数对象、函数嵌套、名称空间与作用域
		一 .函数对象 一 .函数是第一类对象,即函数可以当作数据传递 可以被引用 可以当作参数传递 返回值可以是函数 可以当作容器类型的元素 二. 利用该特性,优雅的取代多分支的if def foo(): ... 
- python基础—函数嵌套与闭包
		python基础-函数嵌套与闭包 1.名称空间与作用域 1 名称空间分为: 1 内置名称空间 内置在解释器中的名称 2 全局名称空间 顶头写的名称 3 局部名称空间 2 找一个名称的查找顺序: ... 
- python之函数对象、函数嵌套、名称空间与作用域、装饰器
		一 函数对象 一 函数是第一类对象,即函数可以当作数据传递 #1 可以被引用 #2 可以当作参数传递 #3 返回值可以是函数 #3 可以当作容器类型的元素 二 利用该特性,优雅的取代多分支的if de ... 
- python基础知识13---函数对象、函数嵌套、名称空间与作用域、装饰器
		阅读目录 一 函数对象 二 函数嵌套 三 名称空间与作用域 四 闭包函数 五 装饰器 六 练习题 一 函数对象 1 函数是第一类对象,即函数可以当作数据传递 #1 可以被引用 #2 可以当作参数传递 ... 
- Python之函数对象、函数嵌套、名称空间与作用域、闭包函数、装饰器
		目录 一 函数对象 二 函数的嵌套 三 名称空间和作用域 四 闭合函数 五 装饰器 一.函数对象 1.函数是第一类对象 #第一类对象的特性:# 可以被引用 # 可以当做参数传递 # 返回值是函数 # ... 
随机推荐
- eclipse maven install 时控制台乱码问题解决
			pom.xml文件中加入: <properties> <argLine>-Dfile.encoding=UTF-8</argLine> <project.bu ... 
- 坑爹的RockSaw和坑爹的windows7
			坑爹的RockSaw和坑爹的windows7 http://chen4w.iteye.com/blog/1153433 
- ArcGIS api for javascript——加入地图并显示x,y坐标
			这个示例报告了用户在地图上悬停和拖拽鼠标的鼠标指针坐标.通过事件监听器来更新鼠标移到的x和y坐标. 下行代码创建了地图: var map = new esri.Map("map") ... 
- 配置CiscoWorks 2000 ANI同步
			配置CiscoWorks 2000 ANI同步 在CiscoWorks 2000的LAN ManagementSolution(LMS)中,Cisco包含了一种ANI的自动发现过程和Res ... 
- Vue总结(一)
			vue总结 构建用户界面的渐进式框架 渐进式:用到什么功能即可使用转么的框架子模块. 两个核心点 向应的数据绑定 当时图发生改变->自动跟新视图,利用Object.defindProperty中 ... 
- React开发实时聊天招聘工具 -第二章
			2-1 介绍React开发环境 npm install -g create-react-app xxx npm run eject 来配置webpack 2-2 ES6常用语法 其他 还有一些特性 ... 
- Scrapy框架之日志等级
			一.日志等级 CRITICAL:严重错误 ERROR:一般错误 WARNING:警告 INFO: 一般信息 DEBUG:调试信息 [注意:默认的日志等级是DEBUG] 二.日志等级设置 修改setti ... 
- selenium使用报错“selenium.common.exceptions.WebDriverException: Message: 'geckodriver' executable needs to be in PATH.”
			安装了python3,使用pip安装了selenium,但是在使用时,报了“selenium.common.exceptions.WebDriverException: Message: 'gecko ... 
- android应用开发-从设计到实现 3-9 Origami动态原型设计
			动态原型设计 动态的可交互原型产品,是产品经理和界面设计师向开发人员阐释自己设计的最高效工具. 开发人员不须要推測设计师要什么样的效果,照着原型产品做就好了. 非常多创业团队也发现了产品人的这个刚需, ... 
- JavaScript提高:006:ASP.NET使用easyUI TABS标签updatepanel
			前文使用了easyui的tab标签.切换问题,使用了session保存当前选中页,然后页面总体刷新时再切换至上次保存页码.那么使用updatepanel后,这个问题就非常好攻克了.http://blo ... 
