27、创建对象
①工厂模式批量创建对象  缺点:无法对象识别,即所有对象都是Object类型;方法内存空间浪费/封装不太完善
function sayName(){    //可以有效节省内存空间
  console.log(this.name);
}
function createObject(name, age, gender){
var obj = {
name:name,
age:age,
gender:gender,
sayName: sayName,    //将方法写在外面,可以有效节省内存空间
};
return obj;    //或者直接返回对象
}
 
var o1 = createObject('zhangsan', 12, 'man');
var o2 = createObject('lisi', 15, 'woman');
var dog = createObject('erha', 4, 'man');
console.log(o1, o2, dog);
//通过实例找构造函数
console.log(o1.constructor);     //Object
 
②构造函数模式创建对象 
自定义构造函数     问题:方法内存空间浪费/封装不太完善
          
function sayName(){    //可以有效节省内存空间
  console.log(this.name);
}
function Person(name, age, gender){
//this指向new关键字创建的实例
this.name = name;
this.age = age;
this.gender = gender;
sayName: sayName,    //将方法写在外面,可以有效节省内存空间
}
var p1 = new Person("terry",11,"man");
console.log(p1)
console.log(p1.constructor);    //[Function: Person]
 
function Dog(name, age, color){
//this指向new关键字创建的实例
this.name = name;
this.age = age;
this.color= color;
sayName: sayName,    //将方法写在外面,可以有效节省内存空间
}
var d1 = new Dog("erha",2,"red");
console.log(d1)
console.log(d1.constructor);   //[Function: Dog]
 
③原型模式创建对象 
问题: 实例的数据隔离不安全,因为里面的数据共享
function Person(){}
Person.prototype.name = 'zhangsan';
Person.prototype.friends = [];
Person.prototype.sayName = function(){
  console.log(this.name);
};
var p1 = new Person();
consoe.log(p1.name);    //zhangsan
var p2 = new Person();
consoe.log(p1.name);    //zhangsan
p1.friends.push('terry');
console.log(p1.friends);  //['terry']
console.log(p2.friends);  //['terry']
console.log(p1.sayName === p2.sayName);   //true
 
④组合使用构造函数模式和原型模式 
//每个实例自有的放到构造函数中,实例共享的放到原型对象中
function Person(name, age, gender){
//this指向new关键字创建的实例
this.name = name;
this.age = age;
this.gender = gender;
this.friends = [];
}
Person.prototype = {    //实例共享的数据
constructor : Person,
sayName:function(){
  alert(this.name);
       }
}
 
var p1 = new Person("terry",11,"man");
console.log(p1);
console.log(p1.constructor);   //{Function: Person]
var p2 = new Person("larry",11,"woman");
p1.friends.push('hello');
console.log(p1.friends);   //['hello']
console.log(p2.friends);   //[]
 
console.log(Person('aaaa'))   //undefined, 因为this指针需要指向new关键字,这里只有Person,没有new,所以它没有返回对象,返回的是undefined
 
28、对象深入了解
          ①可枚举性:
                    在打印一个对象,所能看到的属性,这些属性的可枚举性都是true;
                    for-in循环返回的属性,这些属性的可枚举性也都是true。
 
          ②对象的属性类型:
[[Configurable]]: 表示是否通过delete删除属性从而重新定义属性,能否修改属性的特性,或者能否把属性修改为访问 器属性直接定义在对象中,默认为true)
 
[[Enumerable]]: 表示能否通过for-in循环返回属性。(直接定义在对象中,默认为true)
 
[[Wriable]]: 表示能否修改属性的值。(直接定义在对象中,默认为true)
 
[[Value]]: 包含这个属性的数据值 name:jacky
 
          ③对象的属性特性
var obj = {
  name:'zhangsan',
  age:12,
};
console.log(obj); //{name:'zhangsan', age: 12,}
 
读取属性的特性 Object.getOwnPropertyDescriptor();获取指定属性的描述符该方法接受两个参数, 第一个为属性所在的对象,第二个为要读取其描述符的属性名称
 
//获取属性的描述信息
console.log(Object.getOwnPropertyDescriptor(obj, 'name'));   //{vale: 'zhangsan', writerable:true, enumerable:true, configurable: true}
 
要修改属性默认的特性,必须使用ECMAScript5的Object.defineProperty()方法 defineProperty(属性所在的对象,属性的名字,一个描述符对象);
 
//修改属性的描述信息
Object.defineProperty(obj, 'name', {
//设置属性不可枚举
enumerable: false,   ------->console.log(obj);   //{age:12}
//设置属性不可修改
writable:false,             -------->obj.name = 'lisi'; console.log(obj.name); //zhangsan
//设置属性值
value:'terry',              --------->console.log(obj.name);     //terry
//设置属性是否可以删除delete,是否可以重新定义,是否可以配置
configurable:false,         --------->别人就不能改变这个属性
})
 
④访问器属性      没有值,有get方法和set方法, configurable的属性默认为false
var obj = {
  name:'zhangsan',
  age:12,
  _weight:100,
};
Object.defineProperty(obj, 'weight', {
  get:function(){
    return this._weight-5;
  },
  set:function(param){
    this._weight = param
  },
  //enumerable:true,
});
/*Object.defineProperty(obj, '_weight', {
  enumerable:false
});*/
console.log(obj.weight);   //95
obj.weight = 130
console.log(obj.weight);   //125
console.log(obj._weight);   //130
console.log(obj);  //   {name:'zhangsan', age: 12, weight: [Getter|Setter]}
                    console.log(Object.getOwnPropertyDescript(obj, 'weight'));
console.log(Object.getOwnPropertyDescript(obj, '_weight'));

前端开发JS——对象与原型的更多相关文章

  1. JS对象与原型

    一. JS的对象 1.1 创建对象的几种方式 1.1.1 通过字面量创建对象 在js中,一对{} 其实就是一个对象 var person = { name: "tom", age: ...

  2. js对象,原型,call,apply浅析

    //对象直接量,创建对象最简单的方式是在js里使用对象直接量 var book = { "main title": "js", //属性里有空格,要用引号 &q ...

  3. JavaScript学习(二)——深入学习js对象的原型与继承

    了解对象  什么是对象?   …… 这个就不说了 对象的声明的两种方式 var person = new Object(); person.name="linchen"; pers ...

  4. 深入理解JS对象和原型链

    函数在整个js中是最复杂也是最重要的知识 一个函数中存在多面性: 1.它本身就是一个普通的函数,执行的时候形成的私有作用域(闭包),形参赋值,预解释,代码执行,执行完 成后栈内存销毁/不销毁. 2.& ...

  5. 如何利用fastjson将JSON格式的字符串转换为Map,再返回至前端成为js对象

    //注意,这里的jsonStr是json格式的字符串,里面如果遇到双引号嵌套双引号的,一般是嵌套的双引号经过转义 //    \",假如有这样的一个场景,这些字符串里面有需要的css样式的j ...

  6. 前端开发JS——引用类型

    10.流程控制语句      注:var obj = {}:这里的obj转换boolean语句为true   if语句和java是一样的,判断条件也是根据上篇博客提到的假性值 // 弹出一个带输入框的 ...

  7. JS对象与原型链

    每个函数都存在一个prototype的属性,然后这个属性值为一个对象,我们称之为原型对象 每个对象都存在着一个隐藏的属性"__proto__" 这个属性引用了创建这个对象的函数的p ...

  8. 前端开发JS白板编程题目若干

    在前端开发参加面试的时候,无论是校招还是社招,往往都会碰到让我们直接在白纸或者白板上手撸代码的题目.由于是手撸代码,这些题目肯定不会过于复杂和冗长,否则面试那么一小会时间根本写不完.本文总结了几个我本 ...

  9. js对象4-js原型--杂志

    提问:在js中什么是原型 prototype 每个学js的人都有自己的解释,网上一大堆的解释与应用,但是看了他们的解释表示还是不理解怎么办?(原因是他们说的太天花乱坠了) 官方手册解释:prototy ...

随机推荐

  1. VectorMap.js 矢量地图库 – 快速入门

    VectorMap.js是一个开源地图渲染JavaScript库, 可以使用WebGL或者HTML5两种方式进行交互式矢量地图 (包括“矢量瓦片地图”,一般性矢量数据地图)和 栅格瓦片地图的渲染. W ...

  2. Android 遍历手机应用,跳转应用市场详情页面

    首先遍历手机内应用,找到需要的应用包名: /** * 遍历手机内应用包名 * @param context */ public static void loadApps(Context context ...

  3. linux用户管理章节笔记

    1 更改有效用户组 :newgrp zeng 把当前用户的有效用户组更改为zeng.事后可以使用groups命令查看. 2 在使用useradd命令增加用户时,在/etc/passwd的值一般会参考 ...

  4. Python目录和文件处理总结

    1.判断目录是否存在.判断文件是否存在.创建目录.重命名目录或文件 import os #获取当前目录路径: E:\Work\Projects\python print(os.getcwd()) #判 ...

  5. ubuntu中输入arm-linux-gcc -v出现no such file or directory

    这个问题困扰了我差不多两天时间了,明明已经安装了arm-linux-gcc,且系统变量和用户变量都配置好了 但每次输入arm-linux-gcc -v都会出现如题所示错误.最终经过查到一个帖子有说是因 ...

  6. MATLAB常见的学习率下降策略

    MATLAB常见的学习率下降策略 凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 1. 几种常见的学习率下降策略(learning rate decay st ...

  7. 1.Python网络编程_UDP(简略版)

    # -*- coding: utf-8 -*- #2019-11-24 import socket def recv(): udp_socket=socket.socket(socket.AF_INE ...

  8. [C2] 逻辑回归(Logistic Regression)

    逻辑回归(Logistic Regression) 假设函数(Hypothesis Function) \(h_\theta(x)=g(\theta^Tx)=g(z)=\frac{1}{1+e^{-z ...

  9. MySQL实战45讲学习笔记:第三十七讲

    一.本节概况 今天是大年初二,在开始我们今天的学习之前,我要先和你道一声春节快乐! 在第 16和第 34篇文章中,我分别和你介绍了 sort buffer.内存临时表和 join buffer.这三个 ...

  10. 软件工程实践2019——idea表述及组队

    时间:2019-10-08 随堂 欢迎每个有想法的同学都积极参与idea表述,用心呈现你的心中所想.你心中热爱的,希望在软工实践项目中完成的项目作品.每个愿意表达idea的同学,都有一分钟时间来呈现作 ...