《JavaScript语言精粹》读书笔记——给类型增加方法一节的疑问

最近,在学习《JavaScript语言精粹》这本书,发现译者虽然有很好地翻译文章,却没有对文中有疑问的地方进行改正或加以注释。我接触JavaScript只有一年左右,可能无法很好的理解这门语言,而今天,读到第四章中4.7节——给类型增加方法时遇到了疑问之处:

文中给出了对类型增加方法的示例:

Function.prototype.method = function (name, func) {

this.prototype[name] = func;

return this;

};

这里的示例似乎像是一个”公式“,而接下来的两个具体例子给读者显示了另一种写法:

Number.method(‘integer‘, function() {                     //提取数字中的整数部分

return Math[this < 0 ? ‘ceiling‘ : ‘floor‘ ](this);

});

document.writeln((10/3).integer());    //-3

String.method(‘trim‘,function() {                             //移除字符串末端空白

return this.replace(/^/s+|/s+$/g, ‘‘);

});

document.writeln(‘"" + "    neat   ".trim() + ‘"‘);

好吧,我姑且认为这种写法也是可以的。但是,当我把上面两个示例在FireFox中运行时却报”Number.method is not a function“错误,难道这个写法不对?我又用第一种方式重写这两个方法,确得到了”missing formal parameter“错误,我在这里糊涂了,于是在网上google了一下,发现多数有此错误的问题都是因为他们在function的参数里用了var,这和我这里的情况大相径庭,我只好搜索”JavaScript 给类型增加方法“,发现别人都是用以下写法:

Function.prototype.method=function() { func; return this }

另外,我发现Math中根本没有ceiling方法,这里可能是作者的笔误吧。将上面的方法改写成:

Number.prototype.integer=function(){
  
       return Math[this < 0 ? ‘ceil‘ : ‘floor‘](this);

};
    
 String.prototype.trim=function(){

return this.replace(/^/S+|/s$/g,‘‘);

};

终于,结果正确了,但我却糊涂了,为什么书中要用不能运行的示例来解释4.7节的文字呢,还是说这只是一种表述方式,可以帮助读者理解?可是,用能运行的示例不是更好吗?

时间: 2024-08-05 06:38:32

《JavaScript语言精粹》读书笔记——给类型增加方法一节的疑问的相关文章

JavaScript语言精粹读书笔记- JavaScript对象

JavaScript 对象 除了数字.字符串.布尔值.null.undefined(都不可变)这5种简单类型,其他都是对象. JavaScript中的对象是可变的键控集合(keyed collections). 对象是属性的容器,其中每个属性都拥有名字和值. JavaScript中的对象是无类别的(class-free)的.它对新属性的名字和值没有约束. JavaScript包括一个原型链特性,允许对象继承另一对象的属性. 对象的检索: stooge[“first-name”]或者stooge.

JavaScript语言精粹读书笔记 - JavaScript函数

JavaScript是披着C族语言外衣的LISP,除了词法上与C族语言相似以外,其他几乎没有相似之处. JavaScript 函数: 函数包含一组语句,他们是JavaScript的基础模块单元,用于代码复用.信息隐藏和组合调用. 函数用于指定对象的行为. 函数对象Functions: 在JavaScript中函数就是对象.对象是"键值"对的集合并拥有一个连接到原型对象的隐藏连接. 对象字面量产生的对象连接到Object.prototype.函数对象连接到Function.prototy

JavaScript语言精粹 读书笔记(一)

JavaScript中的“严格模式”. 如果在脚本文件的第一行加入"use strict";  则整个脚本都将以“严格模式”运行.如果语句不在第一行,则无效,整个脚本以“正常模式”运行.PS:只要"use strict"; 不跟在实际运行结果的语句后面,可以不在第一行. 如果"use strict"; 放在一个函数体的第一行,则整个函数以“严格模式”运行. “严格模式”的意义 - 消除Javascript语法的一些不合理.不严谨之处,减少一些怪异

&lt;JavaScript语言精粹&gt;-读书笔记(一)

用object.hasOwnProperty(variable)来确定这个属性名是否为该对象成员,还是来自于原型链. for(my in obj){ if(obj.hasOwnProperty(my)){ ... } } 思考:--用来遍历判断是否有该属性成员,当为一个string var="abcdef"一样的一个字符串时,通过JS代码判断其中是否含有我们需要的某一个字符,比如a,如果有就将其remove 一个属性存取表达式用于指定一个对象或数组的属性或元素. 对象字面量:一个对象字

JavaScript语言精粹 读书笔记(二)

公司的项目突然很忙,看书的进度明显慢下来了,不过还是继续慢慢的学... for in 语句可以用来遍历一个对象中的所有属性名.这个枚举过程将会列出所有的属性——包括函数和可能不关心的原型中的属性,所以有必要过滤那些不想要的值.最常用的过滤器是 hasOwnProperty 方法,以及使用 typeof 来排除函数: var name; for (name in another_stooge) { if (typeof another_stooge[name] !== 'function') {

《JavaScript语言精粹》笔记

Function.prototype.method=function(name,func){    this.prototype[name]=func;    return this;}//1.注释最好使用双斜杠而不是带*斜杠/*2.数字,js不区分整数类型,1和1.0是相等的 * NaN是一个数值,它表示一个不能产生正常结果的运算结果.NaN不等于任何值,包括它自己,可用isNaN(number)检查 * 值Infinity表示所有大于1.79769313486231570e+308的值 */

JavaScript语言精粹学习笔记

0.JavaScript的简单数据类型包括数字.字符创.布尔值(true/false).null和undefined值,其它值都是对象. 1.JavaScript只有一个数字类型,它在内部被表示为64位的浮点数.没有分离出整数,所以1和1.0的值相同. 2.NaN是一个数值,表示一个不能产生正常结果的运算结果.NaN不等于任何值,包括它本身.可以用函数isNaN(number)检测NaN,但是建议用isFinite()来检测某值是否是数字. typeof NaN === ‘number’   /

读《JavaScript语言精粹》笔记

一.一些写代码的注意事项 1.parseInt 的使用 因为在八进制中,8和9不是数字,所以 parseInt("08") parseInt("09") 都会产生0作为结果,会导致程序解析时间和日期出现错误.所以建议使用parseInt将10传入. parseInt("08", 10) 的结果为8 2.当使用for in 循环时,最好加上 for (myvar in obj) { if (obj.hasOwnProperty(myvar)) {

学习javascript语言精粹的笔记

1.枚举: 用for in 语句来遍历一个对象中所有的属性名,该枚举过程将会列出所有的属性也包括涵数和方法,如果我们想过滤掉那些不想要的值,最为常用的过滤器为hasOwnProperty方法,以及使用的typeof来排除, var name; for(name in another_stooge){ if(typeof another_stooge[name] !== "function"){ document.writeln(name + ":" + anothe