//https://xxxgitone.github.io/2017/06/10/JavaScript%E5%88%9B%E5%BB%BA%E5%AF%B9%E8%B1%A1%E7%9A%84%E4%B8%83%E7%A7%8D%E6%96%B9%E5%BC%8F/  出处
function Person() { }
Person.prototype.name = 'jiang'; //为对象 添加属性和方法
var person1 = new Person();
var person2 = new Person();
console.log(person1.name) //jiang
console.log(person2.name) // jiang // console.log(Object.getPrototypeOf(person1)); //输出指定对象原型
// console.log(Person.prototype); //输出原型 //function Person() {
//}
//var person1 = new Person();
//console.log(person1.proto === Person.prototype) // true 对象的proto属性 指向函数原型
//person1 instanceof Person // true instanceof操作符处理对象和函数之间的关系 //Person.prototype.isPrototypeOf(person1) // true 指向调用此方法的对象 返回true 调用通过原型添加的属性或方法
//Person.prototype.isPrototypeOf(person2) // true //Object.getPrototypeOf(person1) === Person.prototype // true // 获取对象原型 //function Person() {
//}
//Person.prototype.constructor === Person // true //这个属性其实就是将原型对象指向关联的构造函数 //function Person() {
//}
//var person1 = new Person()
//person1.constructor === Person // true //那岂不是实例person1也有.constructor属性,其实没有,通过原型链在原型Person.prtototype上面找到的 function Person() {
}
// 原型属性
Person.prototype.name = 'Jiang';
var person1 = new Person()
// 实例属性
person1.name = 'J';
console.log(person1.name) // J //如果在实例属性上没有找到的话,就会在实例的原型上去找,如果原型上还没有,就继续到原型的原型上去找,直到尽头 Object.prototype function Person() {
}
// 原型属性
Person.prototype.name = 'Jiang';
var person1 = new Person()
console.log(person1.name) // Jiang //上面代码中person1实例并没有name属性,但仍然可以输出值,就是在原型上找到的 function Person() {
}
var person1 = new Person()
// 实例属性
person1.name = 'j';
person1.hasOwnProperty('name') // true //使用方法hasOwnProperty,属性只有存在于实例中才会返回true function Person() {
}
Person.prototype.age = '100';
var person1 = new Person()
person1.name = 'j'; 'name' in person1 // true
'age' in person1 // true //前面提到hasOwnProperty方法可用于检测属性是否是实例属性,in则会遍历所有属性,不管是实例上的,还是原型上的 //in操作符有两种使用方式,单独使用和在for - in循环中使用, 先上基础代码
//fon-in, 会遍历所有能够通过对象访问的、可枚举的(enumerated)属性,不管是实例上,还是原型上
for (var prop in person1) {
console.log(prop) // name age
} //Object.keys() 此方法可以获取对象的所有可枚举的属性的名字
var keys = Object.keys(person1)
console.log(keys) // ["name"] var keys = Object.keys(Person.prototype)
console.log(keys) // ["age"] //原型对象Person.prototype的原型就是Object.prototype
   <!--
为了理解原型链系统;我们要将javascript对象分为对象和函数两大类;
1.对象有__proto__属性; 函数有prototype属性;
{
创建空对象时,实际上我们是用Object函数来生成对象的
var o = {}; //有1个_pro属性
var o = Object(); //有1个_pro属性
o.__proto__ === Object.prototype; //true
var p = o.prototype; //未定义
var p1 = o.__proto__; //谷歌调试 包含13属性 使用函数来创建自定义的对象时
function MyObj() { }
var t = typeof MyObj; // 检测对象的类型为 "function"
var mo = new MyObj(); // 用函数创建对象 //该有1个_pro属性
var t = MyObj.prototype; //谷歌调试 包含2个属性constructor和__proto__;
var t1 = MyObj.__proto__; // 谷歌调试 只有 ƒ anonymous() 一般函数默认的prototype是一个对象;它有两个属性constructor和__proto__;
其中constructor属性指向这个函数自身,
__proto__属性指向Object.prototype;
Object函数的prototype属性里没有__proto__属性 }
-->
      var y = function MyObj() { }   //谷歌调试鼠标放在对象上,只有 ƒ MyObj()
y.fn = y.prototype = {
end:function(){}
}; //赋值后y.prototype 包含一个 __proto__
y.prototype = {
axd:function(){}
};
y.prototype["abcd"] =[];

//增加特殊符号属性

        y.prototype[":"] =['1'];

//写法

构造函数模式

function Person(name, job) {
this.name = name
this.job = job
this.sayName = function() {
console.log(this.name)
}
}
var person1 = new Person(‘Jiang’, ‘student’)
var person2 = new Person(‘X’, ‘Doctor’)

原型模式

function Person() {
}
Person.prototype.name = ‘Jiang’
Person.prototype.job = ‘student’
Person.prototype.sayName = function() {
console.log(this.name)
}
var person1 = new Person()

原型 写法2

function Person() {
}
Person.prototype = {
name: ‘jiang’,
job: ‘student’,
sayName: function() {
console.log(this.name)
}
}
var person1 = new Person()
使用这种方式,完全重写了默认的Person.prototype对象,因此 .constructor也不会存在这里


更改原型


    var SmartNode = function (option) {
this._init(option);
}
var t = SmartNode.prototype; //谷歌调试 包含2个属性constructor和__proto__; constructor 指向函数自身
SmartNode.prototype = {
_init:function (A){
alert(A);
       this.r=A.r||10;
},
drawDashLine: function (B){} }
var t1 = SmartNode.prototype; //谷歌调试 包含3个属性,drawDashLine 和_init 和__proto__; constructor找不到了 //prototype 原型
SmartNode.prototype={
AA:function(){}
};
var t2 = SmartNode.prototype; //谷歌 调试 包含2个属性, 一个是AA指向函数,和__proto__ 指向对象. var smartNode = new SmartNode("123456789");

new 之后的对象 包括

  1. r: 10
  2. __proto__:
    1. drawDashLine: ƒ (B)
    2. _init: ƒ (A)
    3. __proto__: Object

js prototype 原型的更多相关文章

  1. 深入理解js——prototype原型

    之前(深入理解js--一切皆是对象)中说道,函数也是一种对象.它也是属性的集合,你也可以对函数进行自定义属性.而JavaScript默认的给了函数一个属性--prototype(原型).每个函数都有一 ...

  2. JS原型,Prototype,原型

    对于javascript这样一种前端语言,个人觉得,要真正的理解其oop, 就必须要彻底搞清楚javascript的对象,原型链,作用域,闭包,以及this所引用的对象等概念.这些对弄明白了,应该就可 ...

  3. 关于JS对象原型prototype与继承,ES6的class和extends · kesheng's personal blog

    传统方式:通过function关键字来定义一个对象类型 1234567891011 function People(name) { this.name = name}People.prototype. ...

  4. JScript中的prototype(原型)属性研究

    今天看到同事使用js中的Prototype,感觉很是新鲜.由此想深入学习一下prototype(英['prəʊtətaɪp] 美['protə'taɪp]n. 原型:标准,模范),在学习prototy ...

  5. 关于js中原型链的理解

    我们创建的每个函数都有一个prototype(原型)属性,这个属性是一个指针,一个对象.无论什么时候,我们只要创建一个新函数,就会根据一组特定的规则为该函数创建一个prototype属性,这个属性对象 ...

  6. js的原型

    在讲js的原型之前,必须先了解下Object和Function. Object和Function都作为JS的自带函数,Object继承自己,Funtion继承自己,Object和Function互相是 ...

  7. JavaScript OOP(三):prototype原型对象(即构造函数的prototype属性)

    通过构造函数生成的实例化对象,无法共享属性或方法(即每个实例化对象上都有构造函数中的属性和方法):造成了一定的资源浪费 function Obj(name,age){ this.name=name; ...

  8. 你不知道的JavaScript--Item15 prototype原型和原型链详解

    用过JavaScript的同学们肯定都对prototype如雷贯耳,但是这究竟是个什么东西却让初学者莫衷一是,只知道函数都会有一个prototype属性,可以为其添加函数供实例访问,其它的就不清楚了, ...

  9. JavaScript prototype原型和原型链详解

    用过JavaScript的同学们肯定都对prototype如雷贯耳,但是这究竟是个什么东西却让初学者莫衷一是,只知道函数都会有一个prototype属性,可以为其添加函数供实例访问,其它的就不清楚了, ...

随机推荐

  1. 【ABCD组】Scrum meeting 3

    前言 第3次会议在6月15日由组长在教9 405召开. 主要对下一步的工作进行说明安排,时长90min. 主要内容 讨论怎么用c#进行下一步系统的完成 任务分配 姓名 当前阶段任务 贡献时间 下阶段任 ...

  2. 【ABCD组】Scrum meeting 5

    前言 第5次会议在6月17日由组长在教9 405召开. 主要对下一步的工作进行说明安排,时长90min. 主要内容 分配下阶段任务,争取在这阶段完成软件的设计阶段 任务分配 姓名 当前阶段任务 贡献时 ...

  3. 【codeforces 789D】Weird journey

    [题目链接]:http://codeforces.com/problemset/problem/789/D [题意] 给你n个点,m条边; 可能会有自环 问你有没有经过某两条边各一次,然后剩余m-2条 ...

  4. 推荐一个同步Mysql数据到Elasticsearch的工具

    把Mysql的数据同步到Elasticsearch是个很常见的需求,但在Github里找到的同步工具用起来或多或少都有些别扭. 例如:某记录内容为"aaa|bbb|ccc",将其按 ...

  5. [bzoj2938][Poi2000]病毒_AC自动机

    病毒 bzoj-2938 Poi-2000 题目大意:给你n个01串,问是否存在一个无限长的01串使得这个01的任意子串都不等于给出的01串. 注释:All_length<=30,000 想法: ...

  6. MySQL数据库——存储和函数

    一.存储过程1 基本语法CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristic ...] routine_body 格式[I ...

  7. php 在同一个表单中加入和改动

    大家写站点的时候可能都会遇到这样的情况,就是写一个表单,这个表单是用来加入一篇文章的,我们屁颠屁颠的在后台接收数据,然后存入数据库.如今有个问题.当你要对该文章进行改动的时候,你是怎么处理的? 我的方 ...

  8. SQL SERVER读书笔记:阻塞与死锁

    阻塞是事务隔离带来的副作用,而并不是SQL SERVER的错. 死锁则是互相争用资源而引发.由于死锁会选择牺牲者,所以死锁的危害没有阻塞大.但有时为了解决死锁,会采取对资源加锁,导致阻塞的方式来避免.

  9. element-UI中table表格的row-click事件怎么获取一行数据的id

    <el-table :data="tableData" style="width: 100%" @row-click="openDetails( ...

  10. 0x61 最短路

    终于会dij了原来我以前写的也是堆优化spfa-_-! poj3662DP 通过spfa来放缩(可怜我去年NOIP的day1t3啊) #include<cstdio> #include&l ...