《javascript模式--by Stoyan Stefanov》书摘--字面量和构造函数
二、字面量和构造函数
1,能够使用对象字面量时,就没理由使用new Object构造函数
// 一个空对象
var 0 = new Object();
console.log( o.constructor === Object ); //true // 一个数值对象
var o = new Object(1);
console.log( o.constructor === Number ); //true
2、自定义构造函数
可重用的成员,比如可重用方法,都应该放置到对象的原型中
3、构造函数的返回值
在构造函数中可以自由返回任意对象,只要它是一个对象。如果不是,并不会造成错误,相反,构造函数将会返回this所引用的对象。
4、构造函数避免使用this
function Sayhello() {
this.name = "finder"; //等同window.name
return this;
} // 以上虽然在ES5得到解决,并且在严格模式中this不会指向 全局变量
// 推荐以下方式
function Sayhello() {
var that = {};
that.name = "finder"; //
return that;
}
5、自调用构造函数
function Sayhello (){
if ( !(this instanceof Sayhello)) {
return new Sayhello();
}
} // 通用方法
function Sayhello (){
if ( !(this instanceof arguments.callee)) {
return new arguments.callee();
}
}
6、数组构造函数的特殊性(数组字面量表示更为安全)
// 一个元素数组
var a = [3];
console.log(a.length); //
console.log(a[0]); // // 三个元素的数组
var a = new Array(3);
console.log(a.length); //
console.log(typeof a[0]); //"undefined" // 如果传入一个浮点数?worst...
var a = [3.14];
console.log(a[0]); // 3.14
var a = new Array(3.14);
console.log(a.length); // RangeError: Invalid array length
7、检查数组性质
参考地址:http://www.nowamagic.net/librarys/veda/detail/1250
// 数组也是对象
typeof []; // "object" // 支付宝同学在用的
if (value instanceof Array ||
(!(value instanceof Object) &&
(Object.prototype.toString.call((value)) == '[object Array]') ||
typeof value.length == 'number' &&
typeof value.splice != 'undefined' &&
typeof value.propertyIsEnumerable != 'undefined' &&
!value.propertyIsEnumerable('splice'))) {
return 'array';
} // 最直接的、简单的方式(在不同 iframe 中创建的 Array 并不共享 prototype)
var arr = [];
arr instanceof Array; // true
arr.constructor == Array; //true // 基于iframe的情况 使用 Douglas Crockford 的方法是可以解决这个问题(《JavaScript 语言精粹》P61)
var is_array = function(value) {
return value &&
typeof value === 'object' &&
typeof value.length === 'number' &&
typeof value.splice === 'function' &&
!(value.propertyIsEnumerable('length'));
}; // 更简单的方法,也是jQuery 正在使用的。淘宝的 kissy 也是使用这种方式
var isArray = function(obj) {
return Object.prototype.toString.call(obj) === '[object Array]';
} // 大而全而cool 判断类型
var is = function (obj,type) {
return (type === "Null" && obj === null) ||
(type === "Undefined" && obj === void 0 ) ||
(type === "Number" && isFinite(obj)) ||
Object.prototype.toString.call(obj).slice(8,-1) === type;
}
// jQuery,Ext3的写法,也是推荐的写法
isArray : function(v){
return toString.apply(v) === '[object Array]';
}
8、JSON
json和文字对象之间唯一的语法差异:属性名必需包装在引号中才能成为合法的JSON,而在对象字面量中,仅当属性名称不是有效的标识符时才会需要引号,比如:字符之间的空格{"first name": "javascript"}
此外,在JSON字符串中,不能使用函数或正则表达式字面量
9、使用JSON
JSON.parse()方法是ES5的一部分,一般情况下可以使用JSON.org库(http://www.json.org/json2.js)以访问JSON对象及其方法。
// JQuery的parseJSON()方法
var data = '{"name": “finder”}';
console.log( JQuery.parseJSON( data.name ) ); // "finder" // 与JSON.parse()相对的方法JSON.stringify()
10、正则表达式字面量
javasript正则表达式也是对象
typeof /\//; //"object" // 创建正则表达式
var re = /\\/g; // 字面量方法创建 推荐
var re = new RegExp("\\\\", "gm"); // 构造函数方法创建
11、正则表达式语法
用斜杠来包装用于匹配的正则表达式模式,在第二个斜杠之后,可以将该模式改为不加引号的字母形式:
- g----全局匹配
- m---多行
- i----大小写敏感的匹配
// 正则表达式使用
var name = "fin123d456e789r".replace(/[0-9]/gi, "");
console.log(name); // "finder"
使用new RegExp()的原因:某些场景无法事先确定模式,而只能在运行时以字符串方式创建。
正则表达式字面量各构造函数之间的其中一个区别在于:字面量在解析时只有一次创建了一个对象,如下例子()
//经测试字面量创建共享一个对象的情况在浏览器里已经不存在了,包括IE6
function getName () {
var person = /[a-z]/;
person.name = "finder";
return person;
} var firstName = getName(),
realName = getName(); console.log(firstName === realName); // false
firstName.name = "liubei";
console.log(realName.name) // "finder"
如代码所示,这样的情况如果在浏览器环境中就可以不用考虑了
注:调用RegExp()时不使用new与使用new效果是相同的
12、基本值类型包装器
javascript有五个基本的值类型:数字,字符串,布尔值,nullt和undefined。除了null和undefined以外,其他三个具有所谓的基本包装对象(primitive wrapper object)。可以使用内置构造函数Number(),String(),Boolean()创建包装对象。
为了基本(primitive)数字和数字对象(object)之间的差异,来个例子
// 一个基本类型
var n = 6;
console.log(typeof n); // number // 一个数值Number对象
var nbj = new Number(6)j;
console.log(typeof nbj); // object
当基本类型使用对象方法的时候它会自动临时转换为一个对象
// 用来作为对象的基本字符串
var name = "finder";
console.log(name.toUpperCase()); // FINDER // 值本身可以作为一个对象
"finder".slice(0,4); // "find" // 与数值的方法相同
(22/7).toPrecision(3); // "3.14"
通常使用包装对象的原因:有扩充值以及持久保存状态的需要,由于基本值类型不是对象,不可能扩充属性
// 基本字符串
var greet = "hello I'm finder"; // 使用split自动从基本数据类型转换为对象
greet.split(" ")[0]; // "hello" // 试图增加一个原始数据类型并不会导致错误
greet.smile = true; // 但,它并不是实际运行。。
typeof greet.smile; // "undefined"
在使用没有带new操作符时,它将转换为一个基本类型
typeof Number(6) // "number"
typeof Number("6") // "number"
typeof Number(new Number()); // "number"
typeof String(6); // "string"
typeof Boolean(1); // "boolean" // 神奇的布尔值~~
Boolean(1).toString(); // "true"
Boolean(0).toString(); // "false"
Boolean().toString(); // "false" // 下面的可以猜到吗???
Boolean(4).toString(); // "true"
Boolean(-4).toString(); // "true"
Boolean(0.1).toString() // "true"
13、错误对象
javascript有一些内置错误函数(error constructor),比如Error(),SyntaxError(),TypeError以及其他,这些都带有throw语句,通过这些错误构造函数创建的错误对象具有下列属性:
name:名称属性,“Error”/更为专门的构造函数,比如"RangeError"
message:字符串
错误对象还有一些其他属性,因浏览器实现不一,并不可靠。
另外,throw适用于任何对象,
try{
// 抛出错误
throw{
name : string,
message : “oop”,
extra : string,
remedy : genericErrorHandler // 指定应该处理该错误的函数
}
}catch(e){
// 通知用户
alert(e.message); // "oop"
e.remedy(); // 调用函数genericErrorHandler
}
// 错误构造函数心函数的形式调用(不带new)时,其表现行为与构造函数(带new)相同,并且返回同一个错误对象
14、常用构造函数
一般情况下,除了Date()构造函数以外,很少需要内置构造函数,下面为常用函数
// Built-in constructors (avoid)
var o = new Object();
var a = new Array();
var re = new RegExp("[a-z]", "g");
var s = new String();
var n = new Number();
var b = new Boolean();
throw new Error("ooooooooops!"); // Literals an primitives (prefer)
var o = {};
var a = [];
var re = /[a-z]/g;
var s = "";
var n = 0;
var b = false;
throw{
name : "Error",
message: "oooooooooops!!!"
}
// or
throw Error("oooooooops!");
《javascript模式--by Stoyan Stefanov》书摘--字面量和构造函数的更多相关文章
- 《JavaScript模式》第3章 字面量和构造函数
@by Ruth92(转载请注明出处) 第3章:字面量和构造函数 一.创建对象的三种方式 // 对象字面量 var car = {goes: "far"}; // 内置构造函数(反 ...
- Javascript模式(第三章字面量与构造函数)------读书笔记
一 对象字面量 1.1对象字面量的语法 1,对象键值对哈希表,在其他的编程语言中称之为“关联数组”, 2 键值对里面的值,可以是原始类型也可以是其他类型的对象,称之为属性,函数称之为方法 3 自定义对 ...
- 《javascript模式--by Stoyan Stefanov》书摘--汇总
<javascript模式--by Stoyan Stefanov>书摘--基本技巧 http://www.cnblogs.com/liubei/p/JavascriptModeLog1. ...
- 《javascript模式--by Stoyan Stefanov》书摘--基本技巧
一.基本技巧 1,变量释放的副作用 a.使用var创建的全局变量(在函数外部创建)不能删除. b.不使用var创建的隐含全局变量(尽管在函数内部创建)可以删除. // 定义三个全局变量 var glo ...
- 《javascript模式--by Stoyan Stefanov》书摘--函数
三.函数 1.函数的命名属性 // IE下不支持name属性 var foo = function bar () { // todo }; foo.name; // "bar" 2 ...
- JavaScript 模式》读书笔记(3)— 字面量和构造函数3
这是字面量和构造函数的最后一篇内容,其中包括了JSON.正则表达式字面量,基本值类型包装器等知识点.也是十分重要的哦. 五.JSON JSON是指JavaScript对象表示以及数据传输格式.它是一种 ...
- 《JavaScript 模式》读书笔记(3)— 字面量和构造函数1
新的篇章开始了,本章开始,所有的内容都是十分有价值和意义的.本章主要的内容包括对象字面量.构造函数.数组字面量.正则字面量.基本值类型字面量以及JSON等.在大家的工作和实际应用中也有一定的指导意义. ...
- JavaScript模式:字面量和构造函数
本篇主要讨论了通过字面量以构造对象的方法,比如对象.数组以及正则表达式等字面量的构造方法,同时还讨论了与类似Object()和Array()等内置构造函数相比,为什么基于字面量表示法是更为可取. 对象 ...
- JavaScript 模式》读书笔记(3)— 字面量和构造函数2
上一篇啊,我们聊了聊字面量对象和自定义构造函数.这一篇,我们继续,来聊聊new和数组字面量. 三.强制使用new的模式 要知道,构造函数,只是一个普通的函数,只不过它却是以new的方式调用.如果在调用 ...
随机推荐
- redhat系统升级openssh到7.5
注意,注意,注意重要的事情说三遍,关于ssh的升级不能完全按照别人的教程进行升级,因为每台生产机器都是不一样的,有可能别人能升级成功但是另外一个就可能会失败,因为每台机器上面跑的应用是不一样的,涉及到 ...
- jQuery实现 自动滚屏操作
实现自动滚屏思路: 1.滚屏即:文本的往上移动一段距离: 2.那么我们使文本每过一段时间就往上移动一段固定距离,就可实现滚屏: 3.直到文本底部出现在浏览器窗口中,专业点就是 文本移动的距离 + 浏览 ...
- double工具类
package com.zq.utils; /** * * 经度数字操作类 * * Created by MyEclipse. Author: ChenBin E-mail: chenbin_2008 ...
- 常用的JavaScript设计模式(一)Constructor(构造器)模式
在es6中,新增了一个语法糖--class,可以说是为JavaScript引入了类的概念.而在传统的JavaScript中,则是通过构造器生成实例对象的. JavaScript支持特殊的constru ...
- PHP的发展历程
PHP的发展历程 了解一门语言,我们必须知道这门语言的发展史,现在我通过版本的变化以时间轴的形式来说明PHP的发展历程. 1.1995年初PHP1.0诞生 Rasmus Lerdof发明了PHP,这是 ...
- Linux的数据传输
1. sz 与 rz sz:将选定的文件从本地发送(send)到远端机器 rz:运行该命令会弹出一个文件选择窗口,从本地选择文件夹,接收(receive)从远端的文件 mac 下使用 brew 安装: ...
- Java学习笔记二十:Java中的内部类
Java中的内部类 一:什么是内部类: (1).什么是内部类呢? 内部类( Inner Class )就是定义在另外一个类里面的类.与之对应,包含内部类的类被称为外部类. (2).那为什么要将一个类定 ...
- linux驱动动态与静态加载
在Linux中驱动的加载方式有动态加载和静态加载.动态加载,即驱动不添加到内核中,在内核启动完成后,仅在用到这一驱动时才会进行加载静态加载,驱动编译进内核中,随内核的启动而完成驱动的加载.添加字符驱动 ...
- Verilog_Day3
内容为书中第5章 条件语句 条件语句必须在过程块语句中使用.所谓过程块语句是指由 initial 和 always 语句引导的执行语句集合.除这两种块语句引导的begin_end块中可以编写条件语句外 ...
- 前端chrome调试技巧
待更新:http://blog.csdn.net/xueer767/article/details/65936204?locationNum=8&fps=1