prototype属性--从入门到入门

干嘛用的

prototype属性用来给对象添加属性和方法的。

如下给Person这个对象添加了salary属性。

<script>
function Person(name,age){
    this.name=name;
    this.age=age;
}

var xiaoming=new  Person("xiaoming",45)
Person.prototype.sallary=null;
xiaoming.salary=4000;
alert(xiaoming.salary)//4000
</script>

为何如此大费周折?

上述代码不要Person.prototype.sallary=null;也可以,所以为啥呢?

看看下面这个例子

function Person(name,age){
    this.name=name;
    this.age=age;
    this.hobby=function(){
        return "watching movies"
        
            }
}

var xiaoming=new  Person("xiaoming",45);
var xiaohong=new Person("xiaohong",34);
alert(xiaoming.name);
alert(xiaohong.name)
alert(xiaohong.hobby===xiaoming.hobby);//false

小明的方法竟然和小红的方法不一样。(哪里不一样?)

function Person(name,age){
    this.name=name;
    this.age=age;
}
    Person.prototype.hobby=function(){
        return "watching movie"
        }

var xiaoming=new  Person("xiaoming",45);
var xiaohong=new Person("xiaohong",34);
alert(xiaoming.name);
alert(xiaohong.name)
alert(xiaohong.hobby===xiaoming.hobby);//true

通过prototype来进行创建就一样了。

参考

javascript中prototype属性 - 简书

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 12,385评论 2 17
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,185评论 18 399
  • 官方中文版原文链接 感谢社区中各位的大力支持,译者再次奉上一点点福利:阿里云产品券,享受所有官网优惠,并抽取幸运大...
    HetfieldJoe阅读 8,087评论 4 14
  • 特别说明,为便于查阅,文章转自https://github.com/getify/You-Dont-Know-JS...
    杀破狼real阅读 4,847评论 0 4
  • 目录 上一章 第二十八章 开始写诗 王晓宁在讯达的最后一天下班时,心里有些伤感,但一想到从今晚就开始写自己的长诗...
    自由的风灵阅读 3,717评论 1 22