無廢話JavaScript教程(全集)第2/4頁(yè)
更新時(shí)間:2008年10月07日 23:28:35 作者:
許多讀者認(rèn)為我那本《JavaScript語言精髓與編程實(shí)踐》讀來辛苦,所以我一直想寫個(gè)簡(jiǎn)單的讀本。索性,這次就寫個(gè)最簡(jiǎn)單的吧。
那么JavaScript當(dāng)然……必然……可以面無愧色地支持直接量了——他們其實(shí)是一個(gè)概念。例如:
// in javascript
var
aByte = 256
只不過在理解的時(shí)候,一定要切記:所有上述的代碼中,所謂直接量或立即值,是指那個(gè)'256',而不是那
個(gè)變量或常量的標(biāo)識(shí)符ABYTE/aByte。更進(jìn)一步的,你要知道JavaScript支持了8種直接量聲明:
--------------------
數(shù)值:支持整數(shù),浮點(diǎn)和0x等進(jìn)制前綴,以及……等等;
布爾值:true/false;
無值:undefined;
函數(shù):function() { ... },也稱為匿名函數(shù);
字符串:使用'..'或"..",支持多行和轉(zhuǎn)義符;
正則表達(dá)式:使用/../..,支持g,i,m等正則配置;
數(shù)組:使用[..],支持嵌套數(shù)組;
對(duì)象:使用{...},支持嵌套對(duì)象聲明;
--------------------
你可以把上述字符量作為一個(gè)個(gè)體,用在代碼——我的意思是表達(dá)式或語句行——的任意位置。用鼻子就可以
進(jìn)行的推論是:
//既然可以寫:
aaa = 'hello, ' + 'world';
//那么就必然可以寫:
bbb = [1,2,3] + [4,5,6];
//同樣也就必然可以寫:
ccc = /abc/ + /cdf/
//同樣:
// ……
如上的,你可以把所有的直接量放在表達(dá)式或語句中間。偶爾的,因?yàn)檎Z法解析的必要,你可能需要用一對(duì)
括號(hào)把這個(gè)直接量括起來——否則語法上會(huì)出現(xiàn)歧義,例如下面這個(gè):
ddd = (function() {}) + (function() {})
好了,直接量原本就這么簡(jiǎn)單,你只需要期望自己還有一個(gè)沒退化的鼻子就好了。
四、原型繼承
原型繼承可能是這個(gè)世界上最簡(jiǎn)單不過的東西了。
我們假定一個(gè)對(duì)象是一張表——偉大的Anders就支持我這個(gè)假設(shè),他說JavaScript的對(duì)象是“屬性包”——
這樣的一個(gè)表中存放的就是“name=value”這樣的“名字/值”對(duì)。當(dāng)我們想用下面的代碼:
aObj.name
去找值(value)時(shí),就在表里查一下(用delphi的人應(yīng)該記得TStringList吧)。對(duì)象,哦,所謂對(duì)象——在
我曾經(jīng)的理解里——就是“帶有繼承關(guān)系的結(jié)構(gòu)體(struct/record)”。那么,繼承關(guān)系是?
是這樣,如果上面的查找不成功,對(duì)于原型繼承來說,只需要在aObj這個(gè)對(duì)象的“原型”中找一下,就成了。
這個(gè)原型也是一個(gè)對(duì)象,記錄在構(gòu)造器函數(shù)的prototype屬性中。例如:
function MyObject() {
// ...
}
MyObject.prototype = xxx;
var aObj = new MyObject()
zzz = aObj.name;
當(dāng)在aObj中找不到name這個(gè)屬性時(shí),按照上面的規(guī)則,就會(huì)去xxx這個(gè)對(duì)象中找,也就是試圖找找"xxx.name"。
由于xxx本身也是一個(gè)對(duì)象,也會(huì)有一個(gè)構(gòu)造器函數(shù)(例如xxxObject()),因此當(dāng)xxx.name也找不到時(shí),就會(huì)
去xxxObject.prototype里面去找……如此……如此深層次的挖掘,直到再也找不到……就返回undefined。
多簡(jiǎn)單啊,所謂原型繼承,只不過是一個(gè)簡(jiǎn)單的檢索規(guī)則。
反過來說,你需要讓aObj能訪問到某個(gè)成員,也只需要修改一下它(或它們——一指類似aObj的實(shí)例)的原型
就好了。這在JavaScript中是非常常用的。例如你想讓所有的string都有某個(gè)屬性:
String.protoype.MyName = 'string'
又例如你想讓所有的對(duì)象都有某個(gè)屬性(或方法,或其它什么東東),那么:
Object.prototype.getMyName = function() {
return this.MyName;
}
多么美好,現(xiàn)在String也能getMyName了,函數(shù)也能getMyName了,所有沒有名字的也有名字了——當(dāng)然,名
字是undefined。
沒名字也是名字,我沒想過你會(huì)不會(huì)變成哲學(xué)瘋子,對(duì)不起。
您可能感興趣的文章:
- JavaScript Break 和 Continue區(qū)別教程
- JavaScript入門教程(1) 什么是JS
- JavaScript 核心參考教程 內(nèi)置對(duì)象
- Aptana調(diào)試javascript圖解教程
- Javascript WebSocket使用實(shí)例介紹(簡(jiǎn)明入門教程)
- javascript教程:關(guān)于if簡(jiǎn)寫語句優(yōu)化的方法
- JavaScript基礎(chǔ)教程之a(chǎn)lert彈出提示框?qū)嵗?/a>
- JavaScript中的style.cssText使用教程
- JavaScript插件化開發(fā)教程 (一)
- JavaScript插件化開發(fā)教程 (二)
- Eclipse配置Javascript開發(fā)環(huán)境圖文教程
- javascript入門教程基礎(chǔ)篇
相關(guān)文章
javascript二維數(shù)組和對(duì)象的深拷貝與淺拷貝實(shí)例分析
這篇文章主要介紹了javascript二維數(shù)組和對(duì)象的深拷貝與淺拷貝,結(jié)合實(shí)例形式分析了JavaScript針對(duì)數(shù)組與對(duì)象的深拷貝及淺拷貝相關(guān)操作技巧,需要的朋友可以參考下2019-10-10JavaScript使用DeviceOne開發(fā)實(shí)戰(zhàn)(四)仿優(yōu)酷視頻應(yīng)用
這篇文章主要介紹了JavaScript使用DeviceOne開發(fā)實(shí)戰(zhàn)(四)仿優(yōu)酷視頻應(yīng)用的相關(guān)資料,需要的朋友可以參考下2015-12-12原生JS實(shí)現(xiàn)簡(jiǎn)單的輪播圖效果
這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)簡(jiǎn)單的輪播圖效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07javascript封裝addLoadEvent實(shí)現(xiàn)頁(yè)面同時(shí)加載執(zhí)行多個(gè)函數(shù)的方法
這篇文章主要介紹了javascript封裝addLoadEvent實(shí)現(xiàn)頁(yè)面同時(shí)加載執(zhí)行多個(gè)函數(shù)的方法,實(shí)例分析了onload事件執(zhí)行的原理與同時(shí)執(zhí)行多個(gè)函數(shù)功能的實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-07-07