JS使用new操作符创建对象的方法分析
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JS使用new操作符创建对象的方法分析,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1757字,纯文字阅读大概需要3分钟。
内容图文
![JS使用new操作符创建对象的方法分析](/upload/InfoBanner/zyjiaocheng/332/c0b373c2bbed4e09bcf68a95d6bbfba0.jpg)
本文实例讲述了JS使用new操作符创建对象的方法。分享给大家供大家参考,具体如下:
在编写js代码时,我们有时会需要使用函数来模拟java中的类,并用它来产生对象,在定义了一个构造函数之后我们需要使用new
操作符来调用调用函数才能得到我们想要的对象。例如:
<script> function Constructor(name){ this.name = name } var person1 = Constructor("张三");//undefined var person2 = new Constructor("张三");//得到一个对象{name:"张三"} console.log(person1); console.log(person2); </script>
运行结果:
如果我们不使用new
操作符调用函数,就只会简单的执行函数,并把函数的返回值赋给person1,所以上面的例子中person1的值是undefined,.
如果我们使用new
操作符调用构造函数,做了哪些事情呢?
1.构造函数没有返回值
使用new
操作符调用函数,会隐式的创建一个对象(我们这里称这个对象为obj),这个对象obj是连接到构造函数的原型上的,即obj会继承构造函数原型上的属性方法,并且构造函数中的this也被绑定到了这个对象上,执行完成后这个对象会被作为返回值返回。
2.构造函数有返回值(这种情况比较少,至少我没用过)
new
出来的值由返回值的prototype
而定
例如:
function Constructor(name){ this.name = name return this.name; } var person = new Constructor("123");//Constructor {name: "123"};Object,因为基本类型的prototype都是Object function Constructor(name){ this.name = name return new String(this.name); } var person = new Constructor("123");//String {0: "1", 1: "2", 2: "3", length: 3, [[PrimitiveValue]]: "123"}, console.log(person);
运行结果:
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于JavaScript相关内容还可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
内容总结
以上是互联网集市为您收集整理的JS使用new操作符创建对象的方法分析全部内容,希望文章能够帮你解决JS使用new操作符创建对象的方法分析所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。