昨天面试出了一道面试题 本人我做错了 于是痛定思痛 再过一遍面向对象

var name="一体机";
var value="infolist"; //构造函数
function Anbay(){
this.name="安备";
this.value="anbay";
} //原型
Anbay.prototype.show=function(message){
alert(this.name);
alert(message);
} //对象
var dbbackup={
name:"迪备",
value:"dbbackup"
} //实例
var anbay=new Anbay()
anbay.show(this.value)//"安备" ,"infolist" 这里的this.value相当于window.value,构造函数被调用构造函数里面的this指向实例 anbay.show(dbbackup.value)//"安备","dbbackup" 这里的value是dbbackup里面的自然不用说,构造函数的作用域没有改变this.name弹出构造函数里面的dbbackup anbay.show.call(dbbackup,this.value)//"迪备","infolist" 这里的构造函数在对象dbbackup中执行,对象dbbackup拥有了所有的属性和方法

  

以下为个人测试得到的一些结果和数据

对理解面向对象很有用

1、属性类型 分为数据属性、访问属性

a.定义一个数据属性

/*var person={
} //属性所在的对象,属性的名字,和一个描述符对象
Object.defineProperty(person,"name",{
writable:false,
value:"Ewarm"
})
alert(person.name)
delete person.name
alert(person.name) var person={
} //属性所在的对象,属性的名字,和一个描述符对象
Object.defineProperty(person,"name",{
enumerable:true,
value:"Ewarm"
})

 

var person={}
Object.defineProperty(person,"name",{
configurable:false,
value:"Ewarm"
})
delete person.name
alert(person.name)//弹出Ewarm
Object.defineProperty(person,"name",{
configurable:true,
value:"Ewarm"
})//抛出错误 不能被定义
Object.defineProperty(person,"name",{
writable:true,
value:"cch"
})
person.name="cch"
alert(person.name)

b.定义一个访问属性
//访问器属性常用设置方式,即设置一个属性值会导致其他属性发生变化

var book={
_year:'2017',
edition:1
};
Object.defineProperty(book,"year",{
get:function(){//get 读取
return this._year;
},
set:function(newValue){ //set 写入
if(newValue>2017){
this._year=newValue;
this.edition+=newValue-2017
}
}
})
book.year=2018;
alert(book.edition)
alert(book._year)

//c.定义访问器的旧方法

var book={
_year:'2017',
edition:1
} book.__defineGetter__("year",function(){
return this._year
})
book.__defineSetter__("year",function(newValue){
if(newValue>2017){
this._year=newValue;
this.edition+=newValue-2017
}
})
book.year=2018
alert(book.edition)//

//d.定义多个属性

var book={}
Object.defineProperties(book,{
_year:{
writable:true,
value:2017
},
edition:{
writable:true,
value:1
},
year:{
get:function(){
return this._year;
},
set:function(newValue){
if(newValue>2017){
this._year=newValue;
this.edition+=newValue-2017
}
}
}
})
var descriptor=Object.getOwnPropertyDescriptor(book,"_year");//数据属性
alert(descriptor.value)
alert(descriptor.configurable)//用Object.defineProperties 这种configure默认为 false
alert(descriptor.enumerable)
alert(typeof descriptor.get);
var descriptor=Object.getOwnPropertyDescriptor(book,"year");
alert(descriptor.value);
alert(descriptor.enumerable);
alert(typeof descriptor.get);

2.创建对象

//a.工厂模式

function createPerson(name,age,job){
var o=new Object();
o.name=name;
o.age=age;
o.job=job;
o.sayName=function(){
alert(this.name)
}
return
}
var person1=createPerson("Ewarm",18,"software Engineer")
var person2=createPerson("CCH",18,"doctor")

//b.构造函数

function Person(name,age,job){
this.name=name;
this.age=age;
this.sayName=function(){
alert(this.name)
}
} var person1=new Person()
var person2=new Person()
var person=new Person("Ewarm",18,"software Engineer")

//1.当构造函数调用

person.sayName()
Person("Greg",27,"Doctor");

//2.当普通函数调用

window.sayName()

//3.在另一个对象的作用域中调用

var o =new Object()
var o={
character:"smart",
name:"Ew",
age:25,
job:"Nurse"
}
console.log(o)
Person.call(o,"cch",18,"nurse")//就是说这个构造函数 在o里面执行并且o里面的该有还是有 调用之后 之前的会被覆盖 没有的会被加上在o里面
o.sayName()
console.log(o)

//4.原型模式

function Person(){
}
Person.prototype.name="Ewarm";
Person.prototype.age="29";
Person.prototype.job="software Engineer";
Person.prototype.sayName=function(){
alert(this.name);
}
var person1=new Person()
//我们可以通过isPrototypeOf()方法来确定对象之间是否存在这种关系,即实例.__proto__是否指向构造函数的原型对象,如果指向那么这个方法返回为ture。
alert(Person.prototype.isPrototypeOf(person1))//true
//ECMAScript5增加了一个新方法 Object.getPrototype() 这个方法返回的是实例.__proto__的值,即构造函数原型对象 alert(Object.getPrototype(person1)==Person.prototype)//emmmm 我用的谷歌 报错了 说是支持可以实现了但没实现

注意:当我们要读取某个对象的某个属性时,都会执行一次搜索,目标是具有给定名字的属性。搜索首先从对象实例开始 问:你有没有我要的东西。如果有返回该属性的值。

如果没有继续往下面查找继续搜索指针指向的原型对象,在原型对那个中查找具有指定名字的属性,如果有返回该属性,如此一直到顶层Object。prototype,还没有返回undefine

原型有好多小细节 使用原型继承存在问题 但有解决的方法 这里我们先只说创建对象这一块

//5.组合使用构造函数和原型模式

//6.动态原型模式

//7.寄生构造函数模式

//8.稳妥构造函数模式

js面向对象知识点之对象属性 创建对象 总结中的更多相关文章

  1. 页面循环绑定(变量污染问题),js面向对象编程(对象属性增删改查),js字符串操作,js数组操作

    页面循环绑定(变量污染问题) var lis = document.querySelectorAll(".ul li") for ( var i = 0 ; i < lis. ...

  2. JS面向对象编程,对象,属性,方法。

    document.write('<script type="text/javascript" src="http://api.map.baidu.com/api?v ...

  3. JS面向对象系列教程 — 对象的基本操作

    面向对象概述  面向对象(Object Oriented)简称OO,它是一种编程思维,用于指导我们如何应对各种复杂的开发场景. 这里说的对象(Object),意思就是事物,在面向对象的思维中,它将一 ...

  4. JS面向对象编程:对象

    一般面向过程的写法都是写很多function,坏处:1.代码复用不好 2.函数名称容易重复冲突 下面介绍面向对象的写法: 在JS中每个函数function都是一个对象. 比如,下面这个就是一个对象,我 ...

  5. JS的从理解对象到创建对象

    JavaScript不是一门真正的面向对象语言,因为它连最基本的类的概念都没有,因此它的对象和基于类的语言中的对象也会有所不同.ECMA-262把对象定义为:“无序属性的集合,其属性可以包含基本值.对 ...

  6. js之oop <二> 对象属性

    js中对象属性可以动态添加和删除.删除对象属性用delete关键字. function obj(){ } var oo = new obj(); oo.a = "a"; oo.b ...

  7. JavaScript之面向对象的概念,对象属性和对象属性的特性简介

    一.大家都知道,面向对象语言有一个标志,那就是他们都有类的概念,通过类我们可以创建任意多个具有相同属性和方法的对象.但ECMAScript(指定JavaScript标准的机构,也就是说JavaScri ...

  8. 原来JS是这样的 - 对象属性

    引子 在上一篇(原来JS是这样的 (2))刚发布的时候就阅读了那篇文章的人可能会注意到那篇曾用过"JavaScript 中万物皆对象"的说法,而在随后我发现错误后立即更新改掉了这个 ...

  9. JS delete 用法(删除对象属性及变量)

    1,对象属性删除 function fun(){ this.name = 'mm'; } var obj = new fun(); console.log(obj.name);//mm delete ...

随机推荐

  1. python之路模块与包

    一.import加载的模块分为四个通用类别:          1 使用python编写的代码(.py文件) 2 已被编译为共享库或DLL的C或C++扩展 3 包好一组模块的包 4 使用C编写并链接到 ...

  2. temp-重庆农商行二次出差

    1, 住宿(远舰商务酒店) 与胡仕川一起住   1722房间,  178-27=151(返现后). 7月30日   7月31日  8月1日 8月2日 8月3日 2, 住宿(郎菲酒店)一个人住, 158 ...

  3. Android 之JDBC

    JDBC(Java DataBase Connectivity)是使用 Java 存取数据库系统的标准解决方案,它将不同数据库间各自差异API与标准 SQL语句分开看待,实现数据库无关的 Java操作 ...

  4. angularjs之ui-bootstrap的Datepicker Popup实现双日期选择控件

    最开始使用ui-bootstrap的Datepicker Popup日期选择插件实现双日期选择时间范围时,在网上搜了一些通过JS去实现的方法,不过后来发现可以不必通过JS去处理,只需要使用其自身的属性 ...

  5. .NET 动态脚本语言

    Script.NET (S#) 是一种允许为你的应用程序自定义行为,与本地.NET对象.类型和组件交互动态的脚本语言.托管应用程序本身可以改变一个xml配置脚本运行时的默认行为,更换绑定的方法,属性, ...

  6. Qt 打开文件的默认路径 QFileDialog::getOpenFileName()

    为了说明QFileDialog::getOpenFileName()函数的用法,还是先把函数签名放在这里:   QString QFileDialog::getOpenFileName (       ...

  7. 关于SSH

    SSH的英文全称是Secure Shell. 传统的网络服务程序,如:ftp和telnet在本质上都是不安全安全安全安全的,因为它们在网络上用明文传送口令和数据,别有用心的人非常容易就可以截获这些口令 ...

  8. maven编译时错误:无效的目标发行版

    (转)Maven 将依赖打进一个jar包 博客分类: maven   maven配置 <?xml version="1.0" encoding="UTF-8&quo ...

  9. 关于 HashMap 随笔

    hashMap 的一些认识: 基于哈希表的Map接口的非同步实现,定义了键映射到值的规则 此实现提供所有可选的映射操作,并允许使用null值和null键 根据hash算法,确定key-value的存贮 ...

  10. idea自我使用简单使用方式和出现的一些简单问题以及常用快捷键

    首先配置完Idea的简单使用步骤后,今天在使用Idea时,一直持续提示web项目404的错误提示,因为之前使用idea时,部署的是springBoot的项目,使用的是SpringBoot自带的Tomc ...