一、ES5的严格模式

  1. 在严格模式下,声明变量必须使用 var
  2. 在严格模式下,不能使用八进制
  3. 在严格模式下,不能使用arguments.callee
  4. 在严格模式下,不能使用eval()    //eval()  可以执行其中的代码串  1 不安全 2污染全局变量
  5. 在严格模式下,不能使用with(obj)  //  方便查找属性  先在obj内部查找 没有在往原型链上查找
  6. 严格模式下delete 删除对象中的属性报错,在普通模式下,使用delete删除变量,不会报错,但是不能删除变量
  7. 全局变量消失(this)
  8. with(obj)//严格模式下报错

    1 with可以简化对象操作,with运行的原理,首先会将所有的变量锁定现在obj的范围内,如果有

    2 // 直接使用,如果没有则根据作用域链的方式向上级查找

  9. 函数中的同名参数(在非严格模式下,形参中出现同名变量,后面的会覆盖掉前面的(覆盖发生在函数调用的时候,传值的过程还是一一对应),严格模式下,不允许函数出现同名参数) ;

  10. ;对象中同名属性(可以忽略的)非严格模式下,对象中出现同名变量,后面的覆盖前面的,严格模式下,会忽略前面的变量直接看最后一个同名属性

二、特性

对具体对象中的属性进行特性的配置

  1  设置单个特性 :    Object.defineProperty(obj, property, descripts)

  • obj:要修饰的对象  property:要修饰的属性   descripts:对象,对象中的属性为要配置的特性选项

  2 设置多个特性:     Object.defineProperties(obj, descripts)

  • obj:你要设置的对象  descripts: 对象  key:value,
  • key:代表的是对象的属性  value:是一个对象,是配置属性的特性的对象

  3 descrips公用属性

  • 枚举性(遍历):enumerable      ,是否可以对属性进行枚举
  • 修改性: writable   不可以修改属性值,但是可以通过配置属性特性中的value来更改属性值
  • 值:value
  • 配置性:configurable   可配置性,是否可以对属性进行特性的配置(默认true 设置为false后 ,之后的设置特性无法在设置生效)。

  4  get 方法(该方法在用户读取对象的属性的时候自动触发,函数的返回值就为读取到的值,如果没有返回值,则为undefined)

  注意:千万不要在get的函数体中读取对象的该属性(死循环) 

 <script>
var obj = {
a: 1,
b: 2
}
5Object.defineProperty(obj, 'a', {
get: function() {
console.log("我被触发了");
return 222;
}
});
console.log(obj.a);
</script>

5  set 方法(该方法也会自动触发,在设置对象的属性的时候触发。return 值没有意义的。)

 <script>
var obj = {
a: 1,
b: 2
}
Object.defineProperty(obj, 'a', {
set: function() {
console.log("我被触发了");
return 333;
}
});
obj.a = 11;
console.log(obj.a);
</script>

  6  如何使用set get 方法进行赋值

 <script>
var obj = {
a: 1,
b: 2
}
/*
需求:
如果给a设置的值为number,则让其设置,如果不是number则设置为999
1、不是在set对a属性真正的赋值(真正的赋值就形成了死循环)
2、引入一个中间值 obj.a = 'i love you'; console.log(obj.a); 999
obj.a = 22; console.log(obj.a); 22
*/
Object.defineProperty(obj, 'a', {
set: function(arg) {
// console.log(typeof arg);
if (typeof arg === 'number') {
this._a = arg; // _a 替补属性 _a没有特殊的含义
} else {
this._a = 999;
}
},
get: function() {
return this._a;
}
});
obj.a = 11;
console.log(obj.a);
obj.a = 'i love you';
console.log(obj.a);
</script>

三、对象的扩展(核心思想;取消对__proto__属性的使用

  1. obj1.isPrototypeOf(obj2)      / / 判断obj1是不是obj2的原型对象 (查找的过程是在原型链上进行查找)
  2. Object.getPrototypeOf(obj)   / /获得obj的原型对象
  3. Object.setPrototypeOf(obj,prototype) / / 设置一个对象的原型对象
  • bj:要设置的对象
  • prototype:要设置的原型对象

  4 对象的扩展性(preventExtensions)

   语法:Object.preventExtensions(obj)   //取消obj对象的扩展性,不能添加属性了,可以读取、删除、修改属性

    语法:isExtensible:Object.isExtensible(obj)  //查看对象的可扩展性,值为布尔类型

 <script>
var obj = {
a: 1,
b: 2
}
obj.c = 3;
console.log(obj);
// 阻止对象的扩展:不能添加属性 可以读取 删除 修改
Object.preventExtensions(obj);
obj.d = 4;
obj.a = 11;
delete obj.b;
console.log(obj.c);
console.log(obj);
// 查看对象是否可以扩展
console.log(Object.isExtensible(obj));
</script>

  5  密封对象(seal)

  语法:Object.seal(obj)  //对obj对象进行密封,不能添加、不能删除 可以修改和读取

  语法:Object.isSealed(obj)  //查看obj对象是否被密封

 <script>
var obj = {
a: 1,
b: 2,
c: 3
}
// 密封对象:不能添加、不能删除 可以修改和读取
Object.seal(obj);
obj.d = 4; // 增加
obj.a = 11; // 修改
delete obj.b; // 删除
console.log(obj.c); // 读取
console.log(obj);
// 查看对象是否被密封
console.log(Object.isSealed(obj));
</script>

  6 冻结对象(freeze)

  语法:Object.freeze(obj)  //将obj对象冻结,obj对象只能读取属性,不能删除、添加、修改属性

  语法:Object.isFrozen(obj)      //查看obj对象是否被冻结

 <script>
var obj = {
a: 1,
b: 2,
c: 3
}
// 冻结对象:不能添加、不能删除 、不能修改 只能读取
Object.freeze(obj);
obj.d = 4; // 增加
obj.a = 11; // 修改
delete obj.b; // 删除
console.log(obj.c); // 读取
console.log(obj);
// 查看对象是否被冻结
console.log(Object.isFrozen(obj));
</script>

ECMAScrip5 二的更多相关文章

  1. 【小程序分享篇 二 】web在线踢人小程序,维持用户只能在一个台电脑持登录状态

    最近离职了, 突然记起来还一个小功能没做, 想想也挺简单,留下代码和思路给同事做个参考. 换工作心里挺忐忑, 对未来也充满了憧憬与担忧.(虽然已是老人, 换了N次工作了,但每次心里都和忐忑). 写写代 ...

  2. 前端开发中SEO的十二条总结

    一. 合理使用title, description, keywords二. 合理使用h1 - h6, h1标签的权重很高, 注意使用频率三. 列表代码使用ul, 重要文字使用strong标签四. 图片 ...

  3. 【疯狂造轮子-iOS】JSON转Model系列之二

    [疯狂造轮子-iOS]JSON转Model系列之二 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇<[疯狂造轮子-iOS]JSON转Model系列之一> ...

  4. 【原】Android热更新开源项目Tinker源码解析系列之二:资源文件热更新

    上一篇文章介绍了Dex文件的热更新流程,本文将会分析Tinker中对资源文件的热更新流程. 同Dex,资源文件的热更新同样包括三个部分:资源补丁生成,资源补丁合成及资源补丁加载. 本系列将从以下三个方 ...

  5. 谈谈一些有趣的CSS题目(十二)-- 你该知道的字体 font-family

    开本系列,谈谈一些有趣的 CSS 题目,题目类型天马行空,想到什么说什么,不仅为了拓宽一下解决问题的思路,更涉及一些容易忽视的 CSS 细节. 解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题 ...

  6. MIP改造常见问题二十问

    在MIP推出后,我们收到了很多站长的疑问和顾虑.我们将所有疑问和顾虑归纳为以下二十个问题,希望对大家理解 MIP 有帮助. 1.MIP 化后对其他搜索引擎抓取收录以及 SEO 的影响如何? 答:在原页 ...

  7. 如何一步一步用DDD设计一个电商网站(二)—— 项目架构

    阅读目录 前言 六边形架构 终于开始建项目了 DDD中的3个臭皮匠 CQRS(Command Query Responsibility Segregation) 结语 一.前言 上一篇我们讲了DDD的 ...

  8. ASP.NET Core 之 Identity 入门(二)

    前言 在 上篇文章 中讲了关于 Identity 需要了解的单词以及相对应的几个知识点,并且知道了Identity处在整个登入流程中的位置,本篇主要是在 .NET 整个认证系统中比较重要的一个环节,就 ...

  9. MVVM模式和在WPF中的实现(二)数据绑定

    MVVM模式解析和在WPF中的实现(二) 数据绑定 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在WPF中 ...

随机推荐

  1. 页面禁止刷新处理Js实现

    document.onkeydown = function(e) { e = window.event || e; var k = e.keyCode; //屏蔽ctrl+R,F5键,ctrl+F5键 ...

  2. JMS学习八(ActiveMQ消息持久化)

    ActiveMQ的消息持久化机制有JDBC,AMQ,KahaDB和LevelDB,还有一种内存存储的方式,由于内存不属于持久化范畴,而且如果使用内存队列,可以考虑使用更合适的产品,如ZeroMQ.所以 ...

  3. [BZO3572][HNOI2014]世界树:虚树+倍增

    分析 思维难度几乎为\(0\)的虚树码农(并不)题. 代码 #include <bits/stdc++.h> #define rin(i,a,b) for(register int i=( ...

  4. Java中使用Scanner类进行键盘的输入详解

    我们在使用Java写代码时,经常会遇到从键盘输入字符串等操作,这时候我们需要用到的是我们的Scanner类来实现获取用户从键盘上的输入操作. Scanner类是一个基于正则表达式的文本扫描器,它可以从 ...

  5. 根据linux自带的JDK,配置JAVA_HOME目录

    在配置hadoop是,进行格式化hadoop的时候,出现找不到jdk 我用centos6.5是64位的, 发现本机有java ,就找了一下其位置 找到了jdk-1.7.0_75 which java ...

  6. vscode中让html中php代码高亮

    找到设置中的文件设置中的files.associations,增加以下内容(注意一下内容要放在右侧的用户设置中,而不是放在中间的默认设置中): { // Configure file associat ...

  7. PM项目跟进护航文档模板

    护航文档 版本需求列表 需求 开发责任人 MMDrawerController.GCDTimer.Speex_armv7s等11个库迁移 熊文杰 相关人员 职称 开发人员 开发 熊文杰 测试 xxx ...

  8. mysql在linux下连接超慢的问题及解决办法

    今天一来公司发现mysql连接很慢很慢!!!!不知为啥!! 从其它地方连接MySQL数据库的时候,有时候很慢.慢的原因有可能是MySQL进行反向DNS解析造成的,这里简单介绍下原理,需要的朋友可以参考 ...

  9. c语言中static关键字用法详解

    个人总结: 1.C不是面向对象的,在c中static修饰的变量或函数仅在当前文件中使用 2.C可以对局部变量使用static修饰(注意面向对象的java则不行),其放在全局区一直存在 概述static ...

  10. 十七、RF中的等待时间

    1.sleep:强制等待n秒 sleep  秒数 2.implicit wait 隐式等待 2.1 get selenium implicit wait  :取隐式等待时间,隐式等待时间默认为0 2. ...