天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

jQuery 劇場版 你必須知道的javascript

一.摘要

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

 

二.前言

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

 

三.Javascript面向對象

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

創建對象

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

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

var objectA = new Object();

 

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

var objectA = Object();


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

創建屬性并賦值

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

objectA.name = "my name";

 

訪問屬性

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

alert(objectA.name);

 

嵌套屬性

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

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

 

使用索引

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

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

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

 

下面幾個語句是等效的:

    objectA["school.college"] = "BITI";    var key = "school.college"    alert(objectA["school.college"]);    alert(objectA["school" + "." + "college"]);        alert(objectA[key]);

 

JSON 格式語法

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

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

    //JSON    var objectA = {      name: "myName",      age: 19,      school:      {        college: "大學",        "high school": "高中"       },      like:["睡覺","C#","還是睡覺"]    }

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

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

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

靜態方法與實例方法

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

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

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

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

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

staticClass.staticMethod();

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

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

 

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

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

 

四.全局對象是window屬性


通常我們在<script>標簽中聲明一個全局變量, 這個變量可以供當前頁面的任何方法使用:

  <script type="text/Javascript">    var objectA = new Object();  </script>

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

window.objectA

五.函數究竟是什么

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

    function myMethod()    {      alert("Hello!");    }    myMethod(); 

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

    window.myMethod = function()    {      alert("Hello!");    }

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

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

    function myMethod()    {      alert("Hello!");    }    window.myMethod = function()    {      alert("Hello!");    }    myMethod = function()    {      alert("Hello!");    }

六."this"究竟是什么

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

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

    var o1 = { name: "o1 name" };    window.name = "window name";    function showName()    {      alert(this.name);    }            o1.show = showName;    window.show = showName;    showName();    o1.show();    window.show();

 

結果:

image

image

image

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

 

七.Javascript中的閉包

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

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

簡單表達:

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

先看下面的例子:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head>  <title></title></head><body>  <div id="divResult"></div>  <script type="text/Javascript">    function start()    {      var count = 0;      window.setInterval(function()      {        document.getElementById("divResult").innerHTML += count + "<br/>";        count++;      }, 3000);    };    start();  </script></body></html>

 

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

image

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

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

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

本文不再詳細講解閉包, 深入學習請參考下面的文章

八.總結

JavaScript技術jQuery 劇場版 你必須知道的javascript,轉載需保留來源!

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

主站蜘蛛池模板: 婷婷四房播客五月天 | 亚洲视频免费看 | 视频成人永久免费看 | 97超碰免费人妻中文 | 春药按摩人妻中文字幕 | 免费麻豆国产黄网站在线观看 | 樱桃熟了A级毛片 | 久久99久久成人免费播放 | 调教椅上的调教SM总裁被调教 | 亚洲欧美日韩在线码不卡 | 熟女啪啪白浆嗷嗷叫 | 亚洲欧美国产视频 | 香蕉久久夜色精品国产小说 | 91精品欧美一区二区三区 | 刺激一区仑乱 | 千禧金瓶梅快播 | 偷拍自偷拍亚洲精品 | 色怕怕| 永久免费在线看mv | 欧美日韩视频一区二区三区 | 免费看国产精品麻豆 | 囯产精品一品二区三区 | 伊人久在线 | 欧美丰满少妇久久无码精品 | 日日夜夜操操操 | 男生插曲女生身全过程 | 欧美精品华人在线 | 国产精品久久久久成人免费 | 一个人免费完整在线观看影院 | 亚洲精品无码国产爽快A片百度 | 国产免费久久爱久久啪 | 99久久精品国产自免费 | 天天插天天射天天干 | 不知火舞vs精子 | 97精品免费视频 | gv肉片视频免费观看 | 无套内谢大学生A片 | 久久内在线视频精品mp4 | 在线视频av大全色久久 | 国产高清亚洲 | 东京热影院 |