js面向对象知识点之对象属性 创建对象 总结中
昨天面试出了一道面试题 本人我做错了 于是痛定思痛 再过一遍面向对象
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面向对象知识点之对象属性 创建对象 总结中的更多相关文章
- 页面循环绑定(变量污染问题),js面向对象编程(对象属性增删改查),js字符串操作,js数组操作
页面循环绑定(变量污染问题) var lis = document.querySelectorAll(".ul li") for ( var i = 0 ; i < lis. ...
- JS面向对象编程,对象,属性,方法。
document.write('<script type="text/javascript" src="http://api.map.baidu.com/api?v ...
- JS面向对象系列教程 — 对象的基本操作
面向对象概述  面向对象(Object Oriented)简称OO,它是一种编程思维,用于指导我们如何应对各种复杂的开发场景. 这里说的对象(Object),意思就是事物,在面向对象的思维中,它将一 ...
- JS面向对象编程:对象
一般面向过程的写法都是写很多function,坏处:1.代码复用不好 2.函数名称容易重复冲突 下面介绍面向对象的写法: 在JS中每个函数function都是一个对象. 比如,下面这个就是一个对象,我 ...
- JS的从理解对象到创建对象
JavaScript不是一门真正的面向对象语言,因为它连最基本的类的概念都没有,因此它的对象和基于类的语言中的对象也会有所不同.ECMA-262把对象定义为:“无序属性的集合,其属性可以包含基本值.对 ...
- js之oop <二> 对象属性
js中对象属性可以动态添加和删除.删除对象属性用delete关键字. function obj(){ } var oo = new obj(); oo.a = "a"; oo.b ...
- JavaScript之面向对象的概念,对象属性和对象属性的特性简介
一.大家都知道,面向对象语言有一个标志,那就是他们都有类的概念,通过类我们可以创建任意多个具有相同属性和方法的对象.但ECMAScript(指定JavaScript标准的机构,也就是说JavaScri ...
- 原来JS是这样的 - 对象属性
引子 在上一篇(原来JS是这样的 (2))刚发布的时候就阅读了那篇文章的人可能会注意到那篇曾用过"JavaScript 中万物皆对象"的说法,而在随后我发现错误后立即更新改掉了这个 ...
- JS delete 用法(删除对象属性及变量)
1,对象属性删除 function fun(){ this.name = 'mm'; } var obj = new fun(); console.log(obj.name);//mm delete ...
随机推荐
- 利用ASCII码生成指定规则的字符串
/** * 上送终端编号的后两位生成规则 总共可以生成 (36*36-1)1295个编号 * 01...09 0A...0Z * 10...19 1A...1Z * ............... * ...
- .net异步性能测试(包括ASP.NET MVC WebAPI异步方法)
很久没有写博客了,今年做的产品公司这两天刚刚开了发布会,稍微清闲下来,想想我们做的产品还有没有性能优化空间,于是想到了.Net的异步可以优化性能,但到底能够提升多大的比例呢?恰好有一个朋友正在做各种语 ...
- python入门之一python安装及程序运行
Python 程序要运行,需要先安装python解释器 PVM(这里可对照java的JVM来理解)实际上,你不需要单独安装,直接安装python后就可以了 1.安装python 下载地址:http:/ ...
- Springboot与Mybatis整合
最近自己用springboot和mybatis做了整合,记录一下: 1.先导入用到的jar包 <dependency> <groupId>org.springframework ...
- 框架应用:Spring framework (三) - JDBC支持
Spring框架是一个一站式的框架,也就是对很多技术和框架做了封装,使其应用更加简便. JDBC的代码过程 /STEP 1. Import required packages import java. ...
- jmeter按比例执行业务场景
可用函数 __counter实现: 函数助手中 找到 __counter,如 ${__counter(false,num)},功能简介 ---- 参数为true,每个用户有自己的计数器 ---- 参数 ...
- 翻译:MariaDB wait/nowait
本文为mariadb官方手册:wait/nowait的译文.原文:https://mariadb.com/kb/en/library/wait-and-nowait/ 从MariaDB 10.3.0开 ...
- servlet生成验证码
1.因为朋友们都说现在很少用java自带的图形用户接口,所以小白的我就没去看awt和swing组件,因为要抓紧时间学习后面的,完了出去找工作,等以后再回来了解awt和swing:所以制作验证码的代码是 ...
- mysql更新某个字符串字段的部分内容
如果现在需要Mysql更新字段重部分数据,而不是全部数据,应该采用何种方法呢?下面介绍了两种情况下Mysql更新字段中部分数据的方法,供您参考. Mysql更新字段中部分数据第一种情况: update ...
- Twitter的分布式系统中ID生成方法——Snowflake
Twitter-Snowflake算法产生的背景相当简单,为了满足Twitter每秒上万条消息的请求,每条消息都必须分配一条唯一的id,这些id还需要一些大致的顺序(方便客户端排序),并且在分布式系统 ...