首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js new一个function都发生了什么

2019-04-10 03:08:56 在ES5当中其实是没有类这个概念的,我们使用js的OOP编程其实是用function模拟了类的实现。...这样我们就实现了一个类的效果,那么new这个function的时候到底都发生了什么呢,为什么fun.name的值就是张三呢,如果我们直接调用TestFun.name会发生什么呢,其实这里会直接输出TestFun...这里就涉及到了作用域的概念,在TestFun,如果没有new这个关键字,这里的this是指向其上层作用域的。一旦使用new关键字后这个作用域就发生了变化。 我们把TestFun输出看一下。...说了这么多,new到底发生了什么呢? MDN上是这么说的 function Foo(){} var o = new Object(); o....但是一般情况下如果function没有return的时候这是一个正常的流程,如果function return了一个Object类型,则new完成以后则会返回这个object,如果是非Object(string

1.8K30

理解jsnew

new 操作符 在有上面的基础概念的介绍之后,在加上new操作符,我们就能完成传统面向对象的class + new的方式创建对象,在Javascript,我们将这类方式成为Pseudoclassical...基于上面的例子,我们执行如下代码 var obj = new Base(); 这样代码的结果是什么,我们在Javascript引擎中看到的对象模型是: ? new操作符具体干了什么呢?...例如代码如下: Base.prototype.toString = function() {     return this.id; } 那么当我们使用new创建一个新对象的时候,根据__proto...于是我们看到了: 构造子,我们来设置‘类’的成员变量(例如:例子的id),构造子对象prototype我们来设置‘类’的公共方法。...于是通过函数对象和Javascript特有的__proto__与prototype成员及new操作符,模拟出类和类实例化的效果。

3.4K40
您找到你想要的搜索结果了吗?
是的
没有找到

js(function(){})()的写法用处

以前看到老师写js的单例模式时疑惑为什么要这么写 var singleton = (function () { var privateVariable; function privateFunction...)... } }; }()); 后来查了下资料,js(function(){…})()立即执行函数写法理解,终于了解了。...来来来,首先嘛,JS函数有两种命名方式 1、一种是声明式。 而声明式会导致函数提升,function会被解释器优先编译。即我们用声明式写函数,可以在任何区域声明,不会影响我们调用。...function XXX(){}1 2、一种是函数表达式 函数表达式我们经常使用,而函数表达式function则不会出现函数提升。而是JS解释器逐行解释,到了这一句才会解释。...var fn2 = function(){}();//对,就是这样 function fn1(){}();//{}会被忽略 而平常的function(){}则是一种声明式,如果加上()括号后,则会被编译器认为是函数表达式

3.4K00

javaScript系列:js获取时间new Date()详细介绍

大家好,又见面了,我是全栈君 var myDate = new Date(); myDate.getYear(); //获取当前年份(2位) myDate.getFullYear(); //获取完整的年份...myDate.toLocaleString( ); //获取日期与时间 ========================================================================== JS...第二种方法: var timestamp =(new Date()).valueOf(); 结果:1280977330748 第三种方法: var timestamp=new Date().getTime...我和同事在用js实现一个显示出分析数据所剩大概时间的过程,时间总是变给0,结果很怪异,最后发现获取时间的时候用的是Date.parse(newDate())获取的时间戳把毫秒改成了000显示,所以时间差计算的不准确...http://hovertree.com/menu/javascript/ js单独调用new Date(),例如document.write(new Date()); 显示的结果是:Mar 31 10

3.1K20

【说站】jsnew关键字的使用过程

jsnew关键字的使用过程 说明 1、new构建函数,在内存创建一个空对象。 2、this指向刚刚创建的空对象,在构造函数执行代码,并为空对象添加属性和方法。 3、返回到这个对象。...实例  function Foo(name, age, sex) {      this.name = name      this.age = age      this.sex = sex      ...如果返回了一个基本数据类型数据,下方的person会生成一个对象      // return {} //如果返回了一个非基本数据类型数据,下方的person为{}  }  var person = new... Foo('小明', '18', '男')  consloe.log(person)  console.log(person.name)  //小明 以上就是jsnew关键字的使用过程,希望对大家有所帮助

84230
领券