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

JavaScript語言中的Literal Syntax特性分析

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

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

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

    我們編寫JS常用的數據類型包括:Number、Boolean、String、Array、Function和Object。其中這里面的Number、Boolean和String屬于簡單類型,文字方式書寫是它們的基本方式,如果用new xxx()來定義反而會讓人覺得是脫褲子打屁。   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 = [null1, 'string', truefunction(){return 'keke';}, new MyObject()];


    比上面精簡的多吧?而且這里數組的文本化方式還可以寫的遠比這復雜的多,比如:

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


    第三個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數據,最后每個鍵值對用","來分隔就行了。

JavaScript技術JavaScript語言中的Literal Syntax特性分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产成人久久蜜一区二区 | 激情小视频 | 欧美三级免费观看 | 国产女人一区二区 | 国产一区二区三区国产精品 | 在线观看www视频 | 国产精选视频在线观看 | 性福利视频 | 亚洲国产激情在线一区 | 在线色资源 | 国产一区二区网站 | 玖玖国产精品视频 | 91精品久久久久久久久中文字幕 | 国产精品久久久久影院色老大 | 亚洲精品久| 巨臀中文字幕一区二区翘臀 | 精品亚洲国产国拍 | 免费精品一区二区三区第35 | 欧美大片a特激情刺激 | 高清国产一区二区三区 | 色多多a| 黑人和黑人激情一级毛片 | 国产成人精品亚洲77美色 | 日本一区二区视频 | 欧美日韩亚洲区久久综合 | 色好吊 | 麻豆91视频| 国产精品 视频一区 二区三区 | 五月天婷婷综合 | 美女视频一区二区三区在线 | 欧美大色网 | 亚洲小说欧美激情另类 | 国产综合在线视频 | 91麻豆精品国产91久久久久久 | 日本精品视频一区二区 | www.色噜噜| 亚洲精品伊人 | 久久久久久久岛国免费播放 | 婷婷六月激情在线综合激情 | 精品一区二区三区波多野结衣 | 波多野结衣在线观看一区二区三区 |