一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

JavaScript語(yǔ)言中的Literal Syntax特性分析

我剛開始學(xué)習(xí)JavaScript的時(shí)候,老是會(huì)被JavaScript里的一些莫名其妙的語(yǔ)法形式搞的糊里糊涂的。而且也不知道到底它支持了多少那些莫名其妙的語(yǔ)法形式?現(xiàn)在通過這個(gè)幾個(gè)月的深入了解,算是把它們弄得比較清楚了,所以下面就來說說JS的Literal Syntax特性。

    JavaScript語(yǔ)言的文本化的特性?My God,難道有哪門語(yǔ)言的編寫不是使用文本嗎?不使用文本還能用啥?用意識(shí)流嗎?真是faint哈。

    雖然我們的每種語(yǔ)言都使用文本來表示,說遠(yuǎn)點(diǎn)asm是文本的吧,BASIC是文本的吧,C/C++、C#、Java啥的都是文本吧。這沒有錯(cuò),它們的語(yǔ)言表達(dá)都是文本形式,可是它們卻不能使用文本來表示所有內(nèi)容。簡(jiǎn)單類型比如數(shù)字啊字符串啊還行,但是C#或Java可以用文本表示一個(gè)對(duì)象實(shí)例嗎(不是用一堆定義語(yǔ)句,然后再new個(gè)對(duì)象實(shí)例哦)?顯然是不行的,然而JavaScript卻提供了對(duì)所有數(shù)據(jù)類型包括復(fù)雜對(duì)象的文本化書寫方式。

    我們編寫JS常用的數(shù)據(jù)類型包括:Number、Boolean、String、Array、Function和Object。其中這里面的Number、Boolean和String屬于簡(jiǎn)單類型,文字方式書寫是它們的基本方式,如果用new xxx()來定義反而會(huì)讓人覺得是脫褲子打屁。   Number: var i = 100; i = 100.11;
 Boolean: 
var b = true; b = false;
 String: 
var str = 'this is a string.';


    對(duì)于復(fù)雜數(shù)據(jù)類型,函數(shù)、數(shù)組和對(duì)象我們?cè)趺崔k呢?函數(shù)不用說了,都是以文本方式定義的。下面就看看數(shù)組和對(duì)象是怎么表示的吧。假如我們有一個(gè)數(shù)組:

 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();


    我們使用文本方式(也就是我們平時(shí)說的初始化方式)來寫這個(gè)數(shù)組它將是:

 var ary1 = [null1, 'string', truefunction(){return 'keke';}, new MyObject()];


    比上面精簡(jiǎn)的多吧?而且這里數(shù)組的文本化方式還可以寫的遠(yuǎn)比這復(fù)雜的多,比如:

   var ary2 = []; //空數(shù)組,相當(dāng)于 new Array();
   var ary3 = [1,[2,[3,[4,[5,[6,[7,[8,[9,[0]]]]]]]]]];


    第三個(gè)ary3是啥數(shù)組,我也不知道了@_@。

    不對(duì)呀,怎么ary[5]是new MyObject()呢?哦,不好意思,我們?cè)賮戆袽yObject示例一下,假如它被定義為:

 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()怎么文本化呢?其實(shí)也很簡(jiǎn)單的了,obj的文本化定義如下:

 var obj = 
     {
         Properties1 : 
1, Properties2 : '2', Properties3 : [3],
         Method1 : 
function(){ return this.Properties1 + this.Properties3[0];},
         Method2 : 
function(){ return this.Preperties2; }
     };


    這個(gè)類實(shí)例的直接文本化定義雖然算不上精簡(jiǎn),但也還不錯(cuò)吧。這樣我們就可以用這個(gè)文本化類實(shí)例去替換ary中那個(gè)new MyObject()了。類實(shí)例文本化定義的語(yǔ)法為,用一對(duì)"{}"表示類,也就說"{}"完全等價(jià)于"new Object()"。然后"{}"內(nèi)按"key:value"組織屬性和方法,key可以是任意[A-Za-z0-9_]的字符組合,甚至數(shù)字開頭都是合法的@_@,value是任何的合法的文本化JavaScript數(shù)據(jù),最后每個(gè)鍵值對(duì)用","來分隔就行了。

JavaScript技術(shù)JavaScript語(yǔ)言中的Literal Syntax特性分析,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产亚洲精品午夜高清影院 | 亚洲女人性视频 | 五月婷婷六月爱 | 成人在线第一页 | 亚洲精品成人 | 91av在线导航 | 日日噜噜噜噜人人爽亚洲精品 | 隔壁搬来黑人巨大中文字幕 | 91国内精品久久久久免费影院 | 欧美精品第一页 | 国产免费久久精品99久久 | 四虎国产精品永久地址99新强 | 图片区小说区激情区偷拍区 | 麻豆一区二区 | 欧美人成网站免费大全 | 夜色福利院在线看青草一 | 亚洲国产高清视频 | 狠狠综合欧美综合欧美色 | 日日嗷| 国产精品特黄一级国产大片 | 日韩激情中文字幕一区二区 | 国产波波社区精品视频 | 亚洲精品人人 | 9久9久女女热精品视频免费观看 | 国产免费播放一区二区 | 一级一级女人18毛片 | 99久久精品一区二区三区 | 在线色资源 | 亚洲欧洲在线观看 | 91福利精品老师国产自产在线 | 久久只这里是精品66 | 国产视频999 | 午夜黄色福利视频 | 久久久国产精品福利免费 | 欧美日韩国产一区二区三区伦 | 看大片全色黄大色黄 | 综合激情区视频一区视频二区 | 色视频免费 | 日韩欧美一区二区三区中文精品 | 亚洲国产成人精品激情 | 国内精品一区二区三区最新 |