use strict

只能出现在脚本代码的开始或者函数体的开始、任何实体语句之前。Javascript的具体实现将它们解析为解释器自有的指令。这个指令的目的是说明后续的代码将会解析为严格代码。

ECMAScript 5中的严格模式是该语言的一个受限子集,修正了语言的重要缺陷,并提供健壮的差错功能和增强的安全机制。

声明对象

对象直接量

	var book={
"main title":"Javascript", //属性名有空格,必须用字符串表示
"sub-title":"The Definitive Guide", //属性名有 - 必须用字符串表示
"for":"all ", //属性名有关键字 ,必须用字符串表示
anthor:{
firstname:"David",
surname:"Flanagan"
}
}

new 对象

原型

每一个Javascript对象(null除外)都和另一个对象关联。这儿的另一个对象就是原型,每一个对象都从原型继承属性。所有通过对象直接量创建的对象都具有相同的原型对象,并可以通过Object.prototype获取原型对象的引用。通过关键字new 和构造函数调用创建的对象的原型就是构造函数的prototype属性的值。

Object.create()的方法,创建一个对象,其中第一参数是这个对象的原型,第二个可选参数用来对对象的属性进行进一步的描述。

删除属性 delete

检测属性

in运算符,hasOwnProperty()和propertyIsEnumerable()方法来检测属性

	print("main title" in book);
print("anthor" in book); // in 检测是否是对象的属性 返回true
print(book.hasOwnProperty("main title")); //hasOwnProperty()方法用来检测给定名字是否是对象的自有属性
print(book.hasOwnProperty("author")); //返回false
print(book.propertyIsEnumerable("author")); //返回false 只有检测到自有属性,且这个属性的可枚举性是true时,返回true。
print("fadaf" in book);
print(book["main title"]!== undefined);
print("publishtime" in book);

<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">in 可以区分不存在的属性和存在但值为undefined的属性。</span>

存储器属性getter和setter

每一个对象都有与之相关的原型、类和可扩展性。

对象的原型属性是用来继承属性的。原型属性时在对象创建之初就设置好的。通过 new 创建的对象使用构造函数的prototype属性作为它们的原型。通过Object.create()创建的对象使用第一个参数作为它们的原型。

	var p=Object.create(point);				//通过原型的方式创建新的对象
print(p);
print(p.isPrototypeOf(point));
print(point.isPrototypeOf(p)); //返回 true 。point 是 p的原型
print(Object.prototype.isPrototypeOf(p)); // Object 是 p的原型

对象的类属性是字符串,用来描述对象的类型信息。

function classOf(o){						//返回任意对象的类
if(o===null) return "NULL";
if(o===undefined) return "Undefined";
return Object.prototype.toString.call(o).slice(8, -1);// 正数第八个到倒数第二个之间的字符
}

对象的可扩展性用以表示可以给对象添加新的属性,所有内置对象和自定义对象都是显示可扩展的,宿主对象的可扩展性是由Javascript引擎定义的。

	Object.preventExtensions(p);				//将对象转换为不可扩展的
print(Object.isExtensible(p)); // 判断对象是否是可扩展的

一旦将对象转换为不可扩展的就无法将其转换回去。preventExtensions只影响到对象本身的可扩展性。如果给一个不可扩展的对象的原型添加属性,这个不可扩展的对象同样会继承这些新的属性。

Object.seal()除了将对象设置为不可扩展之外,还可以将对象的所有自有属性都设置为不可配置的,不能添加、删除、修改,不过已有的可写属性依然可以修改。对以已经封闭的对象是不能解封的,可以使用Object.isSealed()来检测对象是否封闭。

Object.freeze()将更严格的锁定对象----“冻结”,将所有的数据属性都设置为只读,存储器属性将不受影响。使用Object.isFrozen()来检测对象是否冻结。

序列化对象

序列化对象是指对象的状态转换为字符串,也可将字符串还原为对象。Javascript提供来内置函数JSON.stringify()和JSON.parse()用来序列化和还原Javascript对象。

	a={x:1,y:{z:[false,null,""]}};
s=JSON.stringify(a); //
print(s);
m=JSON.parse(s); // m 是 s 的深拷贝
print(m);

版权声明:本文为博主原创文章,未经博主允许不得转载。

Javascript use strict模式和对象的更多相关文章

  1. javascript中的Strict模式

    目录 简介 使用Strict mode strict mode的新特性 强制抛出异常 简化变量的使用 简化arguments 让javascript变得更加安全 保留关键字和function的位置 总 ...

  2. Javascript之严格模式详解

    一.概述 除了正常运行模式,ECMAscript 5添加了第二种运行模式:"严格模式"(strict mode).顾名思义,这种模式使得Javascript在更严格的条件下运行. ...

  3. JavaScript高级---组合模式设计

    一.设计模式 javascript里面给我们提供了很多种设计模式: 工厂.桥.组合.门面.适配器.装饰者.享元.代理.观察者.命令.责任链 在前面我们实现了工厂模式和桥模式 工厂模式 : 核心:为了生 ...

  4. [Javascript] js的类和对象

    类 graph LR 类-->构造函数 类-->prototype对象 类-->instanceof运算符 类-->constructor属性 类-->isPrototy ...

  5. 深入理解JavaScript中创建对象模式的演变(原型)

    深入理解JavaScript中创建对象模式的演变(原型) 创建对象的模式多种多样,但是各种模式又有怎样的利弊呢?有没有一种最为完美的模式呢?下面我将就以下几个方面来分析创建对象的几种模式: Objec ...

  6. JavaScript高级---桥模式设计

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...

  7. javascript常见编程模式举例

    近期买到手了一本<javascript框架设计>,具体介绍开发js框架所用到的知识.初读一点,乐帝脆弱的理论修养就暴露无遗了,所以专门加强理论修养,重看javascript编程模式的举例. ...

  8. javascript设计模式——命令模式

    前面的话 假设有一个快餐店,而我是该餐厅的点餐服务员,那么我一天的工作应该是这样的:当某位客人点餐或者打来订餐电话后,我会把他的需求都写在清单上,然后交给厨房,客人不用关心是哪些厨师帮他炒菜.餐厅还可 ...

  9. javascript设计模式——组合模式

    前面的话 在程序设计中,有一些和“事物是由相似的子事物构成”类似的思想.组合模式就是用小的子对象来构建更大的对象,而这些小的子对象本身也许是由更小的“孙对象”构成的.本文将详细介绍组合模式 宏命令 宏 ...

随机推荐

  1. NC57银行档案和客商银行账号为建行04 UPDATE

    第二步 银行档案 update bd_bankdoc set bankdoccode='04N'|| bankdoccode , pk_banktype='0001ZZ1000000001OCUD' ...

  2. mysql:忘记root密码

    1:修改/etc/my.cnf 2:重启服务 3:进入mysql 4:修改密码 5:刷新权限 注意:修改完成后,别忘了修改/etc/my.cnf,删除skip-grant-tables,否则重启服务后 ...

  3. coderforces 731c

    题目大意:给出m组数据,每组数据包括两个数Li与Ri,分别表示左右袜子的索引(下标),表示这一天要穿的袜子:而我们要使得每天穿的这两只袜子的颜色相同,所以可以改变袜子的颜色,每次只能改变一只袜子的颜色 ...

  4. 【学】jQuery的源码思路3——添加事件及其他

    这段添加的方法有: 各类事件函数 css() addEvent() toggle() //添加各种事件,将常用的事件名称放入数组,然后循环着加入到zQuery对象的原型上 var eventArr = ...

  5. OAF_文件系列7_实现OAF处理Excel的JXL包介绍(概念)

    20150714 Created By BaoXinjian

  6. jQuery中关于height,innerWidth与outerWidth的区别

    jQuery width() 和 height() 方法 width() 方法设置或返回元素的宽度(不包括内边距.边框或外边距). height() 方法设置或返回元素的高度(不包括内边距.边框或外边 ...

  7. 关于android.view.WindowManager$BadTokenException问题出现以及解决的一些记录

    1.出现 在app showdialog()时偶尔会出现,根据stackoverflow.com的描述,貌似是show的时候用作context的activity以及destroy了,,,一些异步操作会 ...

  8. javaEE中关于dao层和services层的理解

    javaEE中关于dao层和services层的理解 入职已经一个多月了,作为刚毕业的新人,除了熟悉公司的项目,学习公司的框架,了解项目的一些业务逻辑之外,也就在没学到什么:因为刚入职, 带我的那个师 ...

  9. 20条Linux命令面试问答

    程序师  http://www.techug.com/20-linux-command-interview-questions 问:1 如何查看当前的Linux服务器的运行级别? 答: ‘who -r ...

  10. CSS鼠标悬停图片加边框效果,不位移的方法

    <!DOCTYPE HTML> <html lang="en-US"> <head> <title>css实现鼠标悬停时图片加边框效 ...