1、属性的标志和描述符

  属性的标志

  对象属性除value外还有三个特殊属性,即标志

  writable ----如果为true,则可以修改,否则它只是只读的。

  enumerable ----如果为true,则可在循环中列出,否则不列出。

  configurable -----如果为true,则此属性可以被删除,相应的特性也可以被修改,否则不可以

  得到这些标志的语法:

  let descriptor = Object.getOwnPropertyDescriptor(obj,propertyName);

  obj   需要获取信息的对象

  propertyName   属性的名称

  let user = {

    name : "Jhon"

  };

  let descriptor = Object.getOwnPropertyDescriptor(user,'name');

  alert(JSON.stringify(descriptor,null,2));

  /* property descriptor:
  {
      "value": "John",
      "writable": true,
      "enumerable": true,
      "configurable": true
  }
  */

  标志修改语法:Object.defineProperty(obj,propertyName,descriptor)

  

 let user = {};

 Object.defineProperty(user, "name", {
value: "John"
}); let descriptor = Object.getOwnPropertyDescriptor(user, 'name'); alert( JSON.stringify(descriptor, null, ) );
/*
{
"value": "John",
"writable": false,
"enumerable": false,
"configurable": false
}
*/

  设置属性只读

  let user = {

    name : "Jhon"

  };

  Object.defineProperty(user,"name",{

    writable:false

  });

  user.name = "XiaoMing";//错误,不能设置只读属性‘name’;

  不可枚举

  通过设置 enumerable 标志可以设置属性是否可以枚举 

  

 let user = {
name: "John",
toString() {
return this.name;
}
}; // 默认情况下,我们的两个属性都会列出:
for (let key in user) alert(key); // name, toString Object.defineProperty(user, "toString", {
enumerable: false
}); // 现在 toString 消失了:
for (let key in user) alert(key); // name

  不可配置

  通过设置configurable 标志,来控制属性是否可以修改

  

 let user = { };

 Object.defineProperty(user, "name", {
value: "John",
writable: false,
configurable: false
}); // 不能修改 user.name 或 它的标志
// 下面的所有操作都不起作用:
// user.name = "Pete"
// delete user.name
// defineProperty(user, "name", ...)
Object.defineProperty(user, "name", {writable: true}); // 错误

  Object.defineProperties

  一次定义多个属性,语法和示例如下:

 Object.defineProperties(obj, {
prop1: descriptor1,
prop2: descriptor2
// ...
});
Object.defineProperties(user, {
name: { value: "John", writable: false },
surname: { value: "Smith", writable: false },
// ...
});

  Object.getOwnPropertyDescriptors(obj)

  一次获取所有属性描述

  语法:let clone = Object.defineProperties({}, Object.getOwnPropertyDescriptors(obj));

2、属性的getter 和 setter

  getter 和 setter  

 let obj = {
get propName() {
// getter, the code executed on getting obj.propName
}, set propName(value) {
// setter, the code executed on setting obj.propName = value
}
};

  访问器描述符 

  • get —— 一个没有参数的函数,在读取属性时工作,
  • set —— 带有一个参数的函数,当属性被设置时调用,
  • enumerable —— 与数据属性相同,
  • configurable —— 与数据属性相同。

  兼容性

 function User(name, birthday) {
this.name = name;
this.birthday = birthday; // age 是由当前日期和生日计算出来的
Object.defineProperty(this, "age", {
get() {
let todayYear = new Date().getFullYear();
return todayYear - this.birthday.getFullYear();
}
});
} let john = new User("John", new Date(, , )); alert( john.birthday ); // birthday 是可访问的
alert( john.age ); // ...age 也是可访问的

这个例子主要解决了,当存储表示一个可以互相转换的值。

3、原型继承

  Prototype

  Prototype 是内部隐藏的,但是可以通过_proto_设置

  let animal = {

    eats:true

  };

  let rabbit = {

    jumps:true

  };

  rabbit._proto_=animal;

  alert(rabbit.eats);

  alert(rabbit.jumps);

4、函数原型

  • F.prototype 属性与 [[Prototype]] 不同。F.prototype 唯一的作用是:当 new F() 被调用时,它设置新对象的 [[Prototype]]
  • F.prototype 的值应该是一个对象或 null:其他值将不起作用。
  • "prototype" 属性在设置为构造函数时仅具有这种特殊效果,并且用 new 调用。
     let animal = {
    eats: true
    }; function Rabbit(name) {
    this.name = name;
    } Rabbit.prototype = animal; let rabbit = new Rabbit("White Rabbit"); // rabbit.__proto__ == animal alert( rabbit.eats ); // true

5、原生的原型

  • 所有的内置对象都遵循一样的模式:

    • 方法都存储在原型对象上(Array.prototypeObject.prototypeDate.prototype 等)。
    • 对象本身只存储数据(数组元素、对象属性、日期)。
  • 基本数据类型同样在包装对象的原型上存储方法:Number.prototypeString.prototypeBoolean.prototype。只有 undefinednull 没有包装对象。
  • 内置对象的原型可以被修改或者被新的方法填充。但是这样做是不被推荐的。只有当添加一个还没有被 JavaScript 引擎支持的新方法的时候才可能允许这样做。

6、原型方法

  • Object.create(proto[, descriptors]) —— 利用给定的 proto 作为 [[Prototype]] 来创建一个空对象。
  • Object.getPrototypeOf(obj) —— 返回 obj[[Prototype]](和 __proto__ getter 相同)。
  • Object.setPrototypeOf(obj, proto) —— 将 obj[[Prototype]] 设置为 proto(和 __proto__ setter 相同)。
  • Object.keys(obj) / Object.values(obj) / Object.entries(obj) —— 返回包含自身属性的名称/值/键值对的数组。
  • Object.getOwnPropertySymbols(obj) —— 返回包含所有自身 symbol 属性名称的数组。
  • Object.getOwnPropertyNames(obj) —— 返回包含所有自身字符串属性名称的数组。
  • Reflect.ownKeys(obj) —— 返回包含所有自身属性名称的数组。
  • obj.hasOwnProperty(key):如果 obj 拥有名为 key 的自身属性(非继承得来),返回 true

  同时我们还明确了 __proto__[[Prototype]] 的 getter/setter,位置在 Object.prototype,和其他方法相同。

  我们可以不借助 prototype 创建一个对象,那就是 Object.create(null)。这些对象被用作是「纯字典」,对于它们而言 "__proto__" 作为键没有问题。

  所有返回对象属性的方法(如 Object.keys 以及其他)—— 都返回「自身」属性。如果我们想继承它们,我们可以使用 for...in

javaScript 基础知识汇总 (十二)的更多相关文章

  1. javaScript 基础知识汇总(二)

    1.运算符 术语或者叫法:一元运算符.二元运算符.运算元(参数) let x=0; x=5+2; //5和2为运算元,“+” 为二元运算符: x=-x; //"-" 为一元运算符 ...

  2. JavaScript 基础知识汇总目录

    一.标签.代码结构.现代模式.变量.数据类型.类型转换 GO 二.运算符.值的比较.交互.条件运算符.逻辑运算符 GO 三.循环 while 和 for .switch语句.函数.函数表达式和箭头函数 ...

  3. javaScript 基础知识汇总 (十)

    1.New Function 语法:let func = new Function ([arg1[, arg2[, ...argN]],] functionBody) //无参数示例: let say ...

  4. javaScript 基础知识汇总 (十五)

    1.模块简介 什么是模块: 模块就是一个文件,一个脚本,通过关键字export 和 import 交换模块之间的功能. export 关键字表示在当前模块之外可以访问的变量和功能. import 关键 ...

  5. javaScript 基础知识汇总 (十四)

    1.回调 什么是回调? 个人理解,让函数有序的执行. 示例: function loadScript(src,callback){ let script = document.createElemen ...

  6. 基础知识《十二》一篇文章理解Cookie和Session

    理解Cookie和Session机制 会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话.常用的会话跟踪技术是Cookie与Session.Cookie通过在客户端记录信息确定 ...

  7. JavaScript基础知识总结(二)

    JavaScript语法 二.数据类型 程序把这些量.值分为几大类,每一类分别叫什么名称,有什么特点,就叫数据类型. 1.字符串(string) 字符串由零个或多个字符构成,字符包括字母,数字,标点符 ...

  8. JavaScript基础知识汇总

    1. 图片热区: <img src="logo.jpg" usemap="#logo"> <map id="logo" n ...

  9. javascript基础学习(十二)

    javascript之BOM 学习要点: 屏幕对象 History对象 Location对象 一.屏幕对象 Screen对象是一个由javascript自动创建的对象,该对象的主要作用是描述客户端的显 ...

随机推荐

  1. java 面向对象 购物车

    一个商城包括多个商品.多个用户.拥有销售商品.展示商品和查找商品功能.2)    一个用户拥有一个购物车,购物车具有结算功能.3)    商城具有名称,静态字符串类型4)    用户类是抽象类,两个子 ...

  2. 利用.swp文件恢复源文件

    使用命令 vim -r filename.swp 保存即可

  3. 【React.js小书】动手实现 React-redux(五):Provider - 方志

    我们要把 context 相关的代码从所有业务组件中清除出去,现在的代码里面还有一个地方是被污染的.那就是 src/index.js 里面的 Index: 1234567891011121314151 ...

  4. PO设计模式-实现移动端自动化测试

    开发环境:python 3.6.5 + selenium 2.48.0 + pytest框架 + Android 5.1 工具:pycharm + Appium + Genymotion 测试机型:S ...

  5. 杂谈php之什么是cgi,fastcgi,fpm,cli,mod

    杂谈PHP极少关注的问题 本话题来自于我使用PHP进行网页爬虫的一次经历.对于一个web开发者来说,PHP解释器本身却知之甚小,实在是惭愧呐! 首先这个话题要从几个提问开始. PHP是什么? 外文名: ...

  6. 4.2英寸的iPhone SE2就要来了!但你还会买单吗?

    SE2就要来了!但你还会买单吗?" title="4.2英寸的iPhone SE2就要来了!但你还会买单吗?"> 与其他手机厂商不同,苹果在手机市场的产品策略很&q ...

  7. Leetcode 981. Time Based Key-Value Store(二分查找)

    题目来源:https://leetcode.com/problems/time-based-key-value-store/description/ 标记难度:Medium 提交次数:1/1 代码效率 ...

  8. Java实体映射工具MapStruct的使用

    官网地址:http://mapstruct.org/ MapStruct 是一个代码生成器,简化了不同的 Java Bean 之间映射的处理,所谓的映射指的就是从一个实体变化成一个实体.例如我们在实际 ...

  9. Linux用户组的添加及属性的更改

    用户组的创建: 12345 groupadd [OPTION] 组名 -g GID 指明GID号:[GID_MIN, GID_MAX] -r 创建系统组 CentOS 6: ID<500 Cen ...

  10. Python爬虫-百度模拟登录(二)

    上一篇-Python爬虫-百度模拟登录(一) 接上一篇的继续 参数 codestring codestring jxG9506c1811b44e2fd0220153643013f7e6b1898075 ...