成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

從零開始學習jQuery之你必須知道的JavaScript

開發 前端
本文是jQuery系列教程的劇場版, 即和jQuery這條主線無關, 主要介紹大家平時會忽略的一些javascript細節. 適合希望鞏固javascript理論知識和基礎知識的開發人員閱讀.

最近面試過一些人, 發現即使經驗豐富的開發人員, 對于一些基礎的理論和細節也常常會模糊. 寫本文是因為就我自己而言第一次學習下面的內容時發現自己確實有所收獲和感悟. 其實我們容易忽視的javascript的細節還有更多, 本文僅是冰山一角. 希望大家都能通過本文有所斬獲.

一. Javascript面向對象

Javascript是一門面向對象的語言, 雖然很多書上都有講解,但還是有很多初級開發者不了解.

創建對象

ps: 以前寫過一篇詳細的創建對象的文章(原型方法, 工廠方法等)但是找不到了, 回頭如果還能找到我再添加進來.下面僅僅簡單介紹.

在C#里我們使用new關鍵字創建對象, 在javascript中也可以使用new關鍵字:

  1. var objectA = new Object(); 

但是實際上"new"可以省略:

  1. var objectA = Object(); 

但是我建議為了保持語法一直, 總是帶著new關鍵字聲明一個對象.

創建屬性并賦值

在javascript中屬性不需要聲明, 在賦值時即自動創建:

  1. objectA.name = "my name"

訪問屬性

一般我們使用"."來分層次的訪問對象的屬性:

  1. alert(objectA.name); 

嵌套屬性

對象的屬性同樣可以是任何javascript對象:

  1. var objectB = objectA;  
  2. objectB.other = objectA;  
  3. //此時下面三個值相當, 并且改變其中任何一個值其余兩個值都改變  
  4. objectA.name;  
  5. objectB.name;  
  6. objectB.other.name; 

使用索引

如果objectA上有一個屬性名稱為"school.college", 那么我們沒法通過"."訪問,因為"objectA.school.college"語句是指尋找objectA的school屬性對象的college屬性.

這種情況我們需要通過索引設置和訪問屬性:

  1. objectA["school.college"] = "BITI";  
  2. alert(objectA["school.college"]); 

下面幾個語句是等效的:

  1. objectA["school.college"] = "BITI";  
  2.  var key = "school.college" 
  3. alert(objectA["school.college"]);  
  4. alert(objectA["school" + "." + "college"]);          
  5. alert(objectA[key]); 

JSON 格式語法

JSON是指Javascript Object Notation, 即Javascript對象表示法.

我們可以用下面的語句聲明一個對象,同時創建屬性:

  1. //JSON  
  2.         var objectA = {  
  3.             name: "myName",  
  4.             age: 19,  
  5.             school:  
  6.             {  
  7.                 college: "大學",  
  8.                 "high school""高中"   
  9.             },  
  10.             like:["睡覺","C#","還是睡覺"]  
  11.         } 

JSON的語法格式是使用"{"和"}"表示一個對象, 使用"屬性名稱:值"的格式來創建屬性, 多個屬性用","隔開.

上例中school屬性又是一個對象. like屬性是一個數組. 使用JSON格式的字符串創建完對象后, 就可以用"."或者索引的形式訪問屬性:

  1. objectA.school["high school"];  
  2. objectA.like[1]; 

靜態方法與實例方法

靜態方法是指不需要聲明類的實例就可以使用的方法.

實例方法是指必須要先使用"new"關鍵字聲明一個類的實例, 然后才可以通過此實例訪問的方法.

  1. function staticClass() { }; //聲明一個類  
  2.    staticClass.staticMethod = function() { alert("static method") }; //創建一個靜態方法  
  3.    staticClass.prototype.instanceMethod = function() { "instance method" }; //創建一個實例方法 

上面首先聲明了一個類staticClass, 接著為其添加了一個靜態方法staticMethod 和一個動態方法instanceMethod. 區別就在于添加動態方法要使用prototype原型屬性.

對于靜態方法可以直接調用:

  1. staticClass.staticMethod(); 

但是動態方法不能直接調用:

  1. staticClass.instanceMethod(); //語句錯誤, 無法運行. 

需要首先實例化后才能調用:

  1. var instance = new staticClass();//首先實例化  
  2. instance.instanceMethod(); //在實例上可以調用實例方法  

二. 全局對象是window屬性

通常我們在  

    
    

    然而我們還應該知道, 實際上全局變量objectA是創建在window對象上, 可以通過window對象訪問到:

    1. window.objectA 

    三. 函數究竟是什么

    我們都知道如何創建一個全局函數以及如何調用:

    1. function myMethod()  
    2. {  
    3. alert("Hello!");  
    4. }   
    5. myMethod();  

    其實同全局對象一樣, 使用function關鍵字創建的方法(也可以創建類)的名稱, 實際上是為window對象創建了myMethod屬性, 并且值是一個匿名方法, 上面的語句等同于:

    1. window.myMethod = function()  
    2. {  
    3. alert("Hello!");  

    無論使用哪種方式聲明, 實際保存時都是使用函數名創建window對象的屬性. 并且值只有函數體沒有函數名稱.

    所以,下面三種聲明方式是等效的:

    1. function myMethod()  
    2. {  
    3. alert("Hello!");  
    4. }  
    5. window.myMethod = function()  
    6. {  
    7. alert("Hello!");  
    8. }  
    9. myMethod = function()  
    10. {  
    11. alert("Hello!");  

    四. "this"究竟是什么

    在C#中,this變量通常指類的當前實例. 在javascript則不同, javascript中的"this"是函數上下文,不是由聲明決定,而是由如何調用決定.因為全局函數其實就是window的屬性, 所以在頂層調用全局函數時的this是指window對象.

    下面的例子可以很好的說明這一切:

    1. var o1 = { name: "o1 name" };  
    2.         window.name = "window name";  
    3.  
    4.         function showName()  
    5.         {  
    6.             alert(this.name);  
    7.         }          
    8.           
    9.         o1.show = showName;  
    10.         window.show = showName;  
    11.  
    12.         showName();  
    13.         o1.show();  
    14.         window.show(); 

    結果:

    從零開始學習jQuery: 你必須知道的javascript

    結果證明在頂層調用函數和使用window對象調用函數時, this都指向window對象. 而在對象中調用函數時this指向當前對象.

    五. javascript中的閉包

    閉包的概念比較難以理解, 先看閉包的定義:

    閉包是一個擁有許多變量和綁定了這些變量的環境的表達式(通常是一個函數),因而這些變量也是該表達式的一部分。

    簡單表達:

    閉包就是function實例以及執行function實例時來自環境的變量.

    先看下面的例子:

    1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
    2. <html xmlns="http://www.w3.org/1999/xhtml">  
    3. <head>  
    4.     <title></title>  
    5. </head>  
    6. <body>  
    7.     <div id="divResult"></div>  
    8.     <script type="text/javascript">  
    9.         function start()  
    10.         {  
    11.             var count = 0;  
    12.             window.setInterval(function()  
    13.             {  
    14.                 document.getElementById("divResult").innerHTML += count + "<br/>";  
    15.                 count++;  
    16.             }, 3000);  
    17.         };  
    18.         start();  
    19.     </script>  
    20. </body>  
    21. </html> 

    count是start函數體內的變量, 通常我們理解count的作用于是在start()函數內, 在調用start()函數結束后應該也會消失.但是此示例的結果是count變量會一直存在,并且每次被加1:

    從零開始學習jQuery(劇場版) 你必須知道的javascript

    因為count變量是setInterval中創建的匿名函數(就是包含count++的函數)的閉包的一部分!

    再通俗的講, 閉包首先就是函數本身, 比如上面這個匿名函數本身, 同時加上在這個函數運行時需要用到的count變量.

    javascript中的閉包是隱式的創建的, 而不像其他支持閉包的語言那樣需要顯式創建. 我們在C#語言中很少碰到是因為C#中無法在方法中再次聲明方法. 而在一個方法中調用另一個方法通常使用參數傳遞數據.

    【編輯推薦】

    1. jQuery實戰之仿Flash跳動的按鈕效果
    2. AJAX/PHP/JQuery/CSS設計拖拉式購物車
    3. 分享24款非常有用的jQuery插件
    4. 分享7個超棒的學習jQuery的網站
    5. jQuery拖動布局實現排序結果同步數據庫
    責任編輯:陳貽新 來源: 張子秋的博客
    相關推薦

    2011-05-24 13:37:16

    jQueryAjax

    2011-05-05 11:03:34

    jQueryjavascript

    2011-06-07 14:15:01

    jQuery

    2009-06-09 10:05:41

    jQuery

    2011-06-09 10:17:17

    jQuery

    2011-06-01 14:51:54

    jQuery

    2011-04-26 15:07:48

    jQuery

    2020-02-28 14:05:00

    Linuxshell命令

    2017-12-07 15:47:25

    2015-01-20 11:24:52

    Win 10

    2012-09-29 09:22:24

    .NETGC內存分配

    2017-12-07 15:28:36

    2012-09-29 10:29:56

    .Net內存分配繼承

    2023-06-02 15:55:42

    JavaScrip開發

    2021-10-29 08:44:22

    推拉機制面試broker

    2017-10-11 15:50:18

    光纖通信傳輸

    2011-11-30 09:09:13

    王濤Windows Pho移動開發

    2015-06-29 09:40:10

    Rails新特性

    2024-03-29 13:17:03

    Docker數據卷Volume

    2021-03-01 07:34:42

    Java泛型ArrayList
    點贊
    收藏

    51CTO技術棧公眾號

    主站蜘蛛池模板: 国产精品视频网址 | 日韩av免费看 | 国产福利在线视频 | 色一情一乱一伦一区二区三区 | 亚洲国产自产 | 亚洲精品久久久久久一区二区 | 日韩成人在线看 | www.国产| 国产69精品久久久久777 | 在线国产中文字幕 | 一本大道久久a久久精二百 国产成人免费在线 | 国产网站在线免费观看 | 香蕉婷婷 | 国产精品1区2区3区 中文字幕一区二区三区四区 | 国产精品99久久久久 | 日韩精品一区二区三区中文在线 | 亚洲a在线观看 | 特一级毛片| 国产98色在线 | 日韩 | 日韩欧美一区二区三区在线播放 | 国产精品九九视频 | 操操日| 色婷婷亚洲一区二区三区 | 国产福利在线 | 激情欧美一区二区三区中文字幕 | 国产区视频在线观看 | 国产精品一区二区无线 | www.国产精 | 国产成人在线视频免费观看 | 日韩欧美国产一区二区 | 欧美 日韩 国产 成人 在线 | av在线免费观看不卡 | 国产伦精品一区二区三区精品视频 | 国产一区二区 | 日韩在线综合 | 欧美国产大片 | 91亚洲精华国产 | 天天天插| 黄在线免费观看 | 欧美成人专区 | 午夜影院在线播放 |