Number: var i = 100; i = 100.11;
Boolean: var b = true; b = false;
String: var str = 'this is a string.';
對于復雜數據類型,函數、數組和對象我們怎么辦呢?函數不用說了,都是以文本方式定義的。下面就看看數組和對象是怎么表示的吧。假如我們有一個數組:
var ary = new Array(6);
ary[0] = null;
ary[1] = 1;
ary[2] = 'string';
ary[3] = true;
ary[4] = function()
{
return 'keke';
};
ary[5] = new MyObject();
我們使用文本方式(也就是我們平時說的初始化方式)來寫這個數組它將是:
var ary1 = [null, 1, 'string', true, function(){return 'keke';}, new MyObject()];
比上面精簡的多吧?而且這里數組的文本化方式還可以寫的遠比這復雜的多,比如:
第三個ary3是啥數組,我也不知道了@_@。
不對呀,怎么ary[5]是new MyObject()呢?哦,不好意思,我們再來把MyObject示例一下,假如它被定義為:
function MyObject()
{
this.Properties1 = 1;
this.Properties2 = '2';
this.Properties3 = [3];
this.toString = function()
{
return '[class MyObject]';
};
}
MyObject.prototype.Method1 = function()
{
return this.Properties1 + this.Properties3[0];
};
MyObject.prototype.Method2 = function()
{
return this.Properties2;
};
那么我們的var obj = new MyObject()怎么文本化呢?其實也很簡單的了,obj的文本化定義如下:
var obj =
{
Properties1 : 1, Properties2 : '2', Properties3 : [3],
Method1 : function(){ return this.Properties1 + this.Properties3[0];},
Method2 : function(){ return this.Preperties2; }
};
這個類實例的直接文本化定義雖然算不上精簡,但也還不錯吧。這樣我們就可以用這個文本化類實例去替換ary中那個new MyObject()了。類實例文本化定義的語法為,用一對"{}"表示類,也就說"{}"完全等價于"new Object()"。然后"{}"內按"key:value"組織屬性和方法,key可以是任意[A-Za-z0-9_]的字符組合,甚至數字開頭都是合法的@_@,value是任何的合法的文本化JavaScript數據,最后每個鍵值對用","來分隔就行了。
新聞熱點
疑難解答