练习题 - js函数
代码贴出来
1 function Cat() {
2 getColor = function(){ console.log(1);}
3 return this;
4 }
5 Cat.getColor = function(){console.log(2);}
6 Cat.prototype.getColor = function(){console.log(3);}
7 var getColor = function(){console.log(4);}
8 function getColor() {console.log(5);}
9
10 // 输出结果
11 Cat.getColor();
12 getColor();
13 Cat().getColor();
14 getColor();
15 new Cat.getColor();
16 new Cat().getColor();
17 new new Cat().getColor();
首先我们来理理这些代码的执行顺序:
先声明
1、var getColor [7]
2、function Cat(){...} [1]
3、function getColor(){...} [8]
接下来顺序执行代码
4、Cat.getColor = function(){...} [5]
5、Cat.prototype.getColor = function(){...} [6]
6、getColor = function(){console.log(4);} [7]
7、Cat.getColor(); [11]
8、getColor(); [12]
9、Cat().getColor(); [13]
10、getColor(); [14]
11、new Cat.getColor(); [15]
12、new Cat().getColor(); [16]
13、new new Cat().getColor(); [17]
所以,
Cat.getColor() //2
∵根据4,Cat.getColor被赋值了一个function,现在执行这个function则打印出2.
【涉及对象的静态方法】
getColor() //4
∵根据6,getColor被赋值了一个function,现在执行这个function则打印出4.
【涉及变量的声明和赋值】
Cat().getColor() //1
∵这个是先运行Cat(),再点上getColor的;Cat()之后是返回this,Cat没有被实例化,所以this是window,同时因为Cat()执行之后getColor被重新赋值,所以打印出1.
【涉及函数的运行、变量作用域、this】
getColor() //1
∵前面的代码把getColor改变了,所以打印了1
【涉及变量的赋值】
new Cat.getColor();//2
这个先执行Cat.getColor()
可以这么理解:
var a = Cat.getColor; // a = Cat.getColor = function(){console.log(2);}
new a(); //打印2
【涉及变量的赋值、对象的实例化】
new Cat().getColor();//3
这个先new Cat(),实例化了,实例化的getColor()是Cat.prototype.getColor = function(){console.log(3);}
可以这么理解:
var a = new Cat(); // 实例化Cat
a.getColor(); // 实例执行这个:Cat.prototype.getColor = function(){console.log(3)}
【涉及对象的实例化,实例的原型方法】
new new Cat().getColor();//3
这个先new Cat(),实例化了,实例化的getColor()是Cat.prototype.getColor = function(){console.log(3);},再new
可以这么理解:
var a = new Cat(); // 实例化Cat
var b = a.getColor; // 实例执行这个:b = Cat.prototype.getColor = function(){console.log(3)}
new b(); // 打印3
【涉及变量的赋值,对象的实例化,实例的原型方法】
练习题 - js函数的更多相关文章
- Js函数初学者练习(一)switch-case结构实现计算器。
前 言 JRedu 给大家介绍一点JS函数的练习题希望初学者多做一些练习能够更好的掌握JS的函数,以及能够提升大家的逻辑思维.(我也是个渣渣希望路过的大神多提建议或意见) 希望能够对大家有所帮助 ...
- 3.3 js函数
1.函数语法: 函数声明的方式:function 函数名(参数1,参数2-){//函数体;}函数调用:函数名(参数1,参数2-); 函数内不一定都指定返回值. 如果需要指定返回值,可用 return ...
- Js函数function基础理解
正文:我们知道,在js中,函数实际上是一个对象,每个函数都是Function类型的实例,并且都与其他引用类型一样具有属性和方法.因此,函数名实际上是指向函数对象的指针,不与某个函数绑定.在常见的两种定 ...
- js函数表达式和函数声明的区别
我们已经知道,在任意代码片段外部添加包装函数,可以将内部的变量和函数定义"隐 藏"起来,外部作用域无法访问包装函数内部的任何内容. 例如: var a = 2; function ...
- 通用js函数集锦<来源于网络> 【二】
通用js函数集锦<来源于网络> [二] 1.数组方法集2.cookie方法集3.url方法集4.正则表达式方法集5.字符串方法集6.加密方法集7.日期方法集8.浏览器检测方法集9.json ...
- 通用js函数集锦<来源于网络/自己> 【一】
通用js函数集锦<来源于网络/自己>[一] 1.返回一个全地址2.cookie3.验证用户浏览器是否是微信浏览器4.验证用户浏览器是否是微博内置浏览器5.query string6.验证用 ...
- 100多个基础常用JS函数和语法集合大全
网站特效离不开脚本,javascript是最常用的脚本语言,我们归纳一下常用的基础函数和语法: 1.输出语句:document.write(""); 2.JS中的注释为//3.传统 ...
- JS函数
1.document.write(""); 输出语句2.JS中的注释为//3.传统的HTML文档顺序是:document->html->(head,body)4.一个浏 ...
- js函数和运算符
函数是由事件驱动或者它被调用时执行可重复使用的代码块. <script> function myFunction(){ Alert(“hello World!”): } </scri ...
随机推荐
- js 对象字面量
对象字面量的输出方式以及定义好处 1.对象字面量的输出方式有两种:传统的'.' 例如:box.name 以及数组方式,只不过用数组方式输出时,方括号里面要用引号括起来 例如:box['name'] v ...
- 全面了解linux情况常用命令
查看linux服务器CPU详细情况1. 显示CPU个数命令 # cat /proc/cpuinfo | grep "physical id" | sort | uniq | wc ...
- hive对有null值的列进行avg,sum,count等操作时会不会过滤null值
在hive中,我们经常会遇到对某列进行count.sum.avg等操作计算记录数.求和.求平均值等,但这列经常会出现有null值的情况,那这些操作会不会过滤掉null能呢? 下面我们简单测试下: wi ...
- 注册Windows service及其相关
注册Windows service,.net写的 net stop "xxxxxx""%SYSTEMROOT%\Microsoft.NET\Framework\v2.0. ...
- 借鉴一些关于js框架的东西
八款Js框架介绍及比较,Dojo .Scriptaculous .Prototype .yui-ext .Jquery .Mochikit.mootools .moo.fx,componentartu ...
- Nginx学习记录(二)
1. 什么是反向代理 正向代理 反向代理: 反向代理服务器决定哪台服务器提供服务. 返回代理服务器不提供服务器.也是请求的转发. 反向代理(Reverse Proxy)方式是指以代理服务器来接受Int ...
- 箭头函数 -------JavaScript
本文摘要:http://www.liaoxuefeng.com/ ES6标准新增了一种新的函数:Arrow Function(箭头函数). 为什么叫Arrow Function?因为它的定义用的就是一 ...
- GPT分区表的备份与恢复
GPT分区表的备份与恢复 keenshoes 2016-01-13 21:02:25 关键词: GPT, Partition, MBR,APPLE, GUID, Protective MBR 对于现 ...
- 简单的Maven+SpringMVC
一.SpringMVC非注解编程 1:修改pom.xml文件(相当于非Maven项目的导入jar包) <!-- https://mvnrepository.com/artifact/org.sp ...
- 扒一扒 EventServiceProvider 源代码
Ajax用一句话来说就是无须刷新页面即可从服务器取得数据.注意,虽然Ajax翻译过来叫异步JavaScript与XML,但是获得的数据不一定是XML数据,现在服务器端返回的都是JSON格式的文件. 完 ...