精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

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

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

最近面試過一些人, 發(fā)現(xiàn)即使經(jīng)驗豐富的開發(fā)人員, 對于一些基礎的理論和細節(jié)也常常會模糊. 寫本文是因為就我自己而言第一次學習下面的內(nèi)容時發(fā)現(xiàn)自己確實有所收獲和感悟. 其實我們?nèi)菀缀鲆暤膉avascript的細節(jié)還有更多, 本文僅是冰山一角. 希望大家都能通過本文有所斬獲.

一. Javascript面向?qū)ο?/STRONG>

Javascript是一門面向?qū)ο蟮恼Z言, 雖然很多書上都有講解,但還是有很多初級開發(fā)者不了解.

創(chuàng)建對象

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

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

  1. var objectA = new Object(); 

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

  1. var objectA = Object(); 

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

創(chuàng)建屬性并賦值

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

  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對象表示法.

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

  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的語法格式是使用"{"和"}"表示一個對象, 使用"屬性名稱:值"的格式來創(chuàng)建屬性, 多個屬性用","隔開.

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

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

靜態(tài)方法與實例方法

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

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

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

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

對于靜態(tài)方法可以直接調(diào)用:

  1. staticClass.staticMethod(); 

但是動態(tài)方法不能直接調(diào)用:

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

需要首先實例化后才能調(diào)用:

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

二. 全局對象是window屬性

通常我們在  

    
    

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

    1. window.objectA 

    三. 函數(shù)究竟是什么

    我們都知道如何創(chuàng)建一個全局函數(shù)以及如何調(diào)用:

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

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

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

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

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

    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"是函數(shù)上下文,不是由聲明決定,而是由如何調(diào)用決定.因為全局函數(shù)其實就是window的屬性, 所以在頂層調(diào)用全局函數(shù)時的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(); 

    結(jié)果:

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

    結(jié)果證明在頂層調(diào)用函數(shù)和使用window對象調(diào)用函數(shù)時, this都指向window對象. 而在對象中調(diào)用函數(shù)時this指向當前對象.

    五. javascript中的閉包

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

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

    簡單表達:

    閉包就是function實例以及執(zhí)行function實例時來自環(huán)境的變量.

    先看下面的例子:

    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函數(shù)體內(nèi)的變量, 通常我們理解count的作用于是在start()函數(shù)內(nèi), 在調(diào)用start()函數(shù)結(jié)束后應該也會消失.但是此示例的結(jié)果是count變量會一直存在,并且每次被加1:

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

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

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

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

    【編輯推薦】

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

    2011-05-24 13:37:16

    jQueryAjax

    2011-06-07 14:15:01

    jQuery

    2011-05-05 11:03:34

    jQueryjavascript

    2009-06-09 10:05:41

    jQuery

    2011-06-09 10:17:17

    jQuery

    2011-06-01 14:51:54

    jQuery

    2012-09-29 10:29:56

    .Net內(nèi)存分配繼承

    2012-09-29 09:22:24

    .NETGC內(nèi)存分配

    2017-12-07 15:28:36

    2017-12-07 15:47:25

    2020-02-28 14:05:00

    Linuxshell命令

    2011-04-26 15:07:48

    jQuery

    2015-01-20 11:24:52

    Win 10

    2021-10-29 08:44:22

    推拉機制面試broker

    2023-06-02 15:55:42

    JavaScrip開發(fā)

    2024-03-29 13:17:03

    Docker數(shù)據(jù)卷Volume

    2021-03-01 07:34:42

    Java泛型ArrayList

    2015-07-23 10:37:13

    Linux命令

    2011-11-30 09:09:13

    王濤Windows Pho移動開發(fā)

    2015-06-29 09:40:10

    Rails新特性
    點贊
    收藏

    51CTO技術棧公眾號

    久热精品在线观看| 亚洲 中文字幕 日韩 无码| 精品人妻一区二区三区四区不卡 | 国产在线拍揄自揄拍视频| 国产九九视频一区二区三区| 久久久免费精品| 我不卡一区二区| www.欧美| 欧美日韩中文字幕综合视频| 亚洲国产欧洲综合997久久| www.激情五月.com| 久久精品女人| 精品少妇v888av| 中文字幕免费高清| 视频一区视频二区欧美| 在线观看国产一区二区| 欧美另类videosbestsex日本| 日本电影一区二区在线观看| 麻豆成人在线观看| 欧美一区二区三区图| 五月天av网站| 精品国产一区探花在线观看| 欧美mv日韩mv国产| 欧美大尺度做爰床戏| 好吊日av在线| 中文字幕在线视频一区| 你懂的网址一区二区三区| www.久久色| 日韩成人伦理电影在线观看| 97国产suv精品一区二区62| 久久精品日韩无码| 久久93精品国产91久久综合| 精品盗摄一区二区三区| 亚洲一区二区在线视频观看| 成人影院大全| 午夜视频在线观看一区| 今天免费高清在线观看国语| 国产小视频福利在线| av网站免费线看精品| 91免费高清视频| 特级西西444www高清大视频| 国产精品一二| 91国内免费在线视频| 九九视频在线观看| 亚洲最新色图| 久久久999精品视频| 免费一级特黄3大片视频| 亚洲日产av中文字幕| 精品国产乱码久久久久久1区2区| 天堂视频免费看| 成人自拍视频网| 91国在线观看| 欧美精品无码一区二区三区| 樱桃视频成人在线观看| 婷婷久久综合九色综合绿巨人 | 亚洲综合日韩在线| 国产精品高潮呻吟av| 免费成人av在线播放| 国产精品视频白浆免费视频| 特级西西444www高清大视频| 日韩中文字幕区一区有砖一区| 欧日韩不卡在线视频| 日本道在线观看| 性欧美长视频| 情事1991在线| 中文字幕 国产精品| 日本一不卡视频| 国产欧美va欧美va香蕉在| 国产又粗又黄又爽视频| 韩国视频一区二区| 99视频免费观看| 天堂网在线中文| 国产亚洲综合在线| 亚洲精品美女久久7777777| 97在线观看免费观看高清| 国产精品久久久久久久岛一牛影视 | 欧美高清自拍一区| 国产极品在线播放| 国产精品毛片| 国产精品免费小视频| 国产精品久久久久久无人区| 高清成人免费视频| 麻豆亚洲一区| 日本中文字幕在线观看| 一区二区三区高清在线| 欧美精品色婷婷五月综合| 99久久婷婷国产综合精品首页| 欧美日韩国产一级二级| 久久久久亚洲av无码网站| 久久精品国产亚洲5555| 国产一区二区三区在线观看视频| 中文字幕求饶的少妇| 亚洲国产专区校园欧美| 国产精品av免费在线观看| 国产日韩免费视频| 99re热这里只有精品免费视频| 无遮挡亚洲一区| 日本大胆在线观看| 在线观看免费一区| 亚洲区 欧美区| 国产精品入口久久| 欧美裸身视频免费观看| 欧产日产国产69| 国产一区二区影院| 欧美日韩大片一区二区三区| 黄网站在线播放| 精品美女久久久久久免费| 亚洲成人天堂网| 国内露脸中年夫妇交换精品| 中文字幕日韩在线观看| 91porny在线| 精品一区二区在线观看| 久久久99爱| av在线免费网站| 在线免费精品视频| 艳妇乳肉亭妇荡乳av| 偷拍欧美精品| 国产精品激情av电影在线观看| 亚洲国产www| 国产精品国产三级国产普通话三级| cao在线观看| 清纯唯美激情亚洲| 日韩小视频在线观看| 日韩精品成人免费观看视频| 成人午夜免费av| 麻豆视频传媒入口| **国产精品| 视频在线观看99| 99精品人妻国产毛片| 99在线热播精品免费| 男人日女人的bb| 亚洲欧美专区| 在线视频免费一区二区| 免费av中文字幕| 久久久久久久综合色一本| 精品无码国产一区二区三区av| www.成人在线.com| 精品国产依人香蕉在线精品| 嫩草影院一区二区三区| 国产亚洲精品中文字幕| 漂亮人妻被中出中文字幕| 精品久久对白| 77777亚洲午夜久久多人| 成人无码一区二区三区| 亚洲激情五月婷婷| 国产一精品一aⅴ一免费| 1024精品久久久久久久久| 国产区亚洲区欧美区| av资源在线观看免费高清| 欧洲av在线精品| 色欲AV无码精品一区二区久久| 狂野欧美一区| 午夜视频久久久| 超薄肉色丝袜脚交一区二区| 国产一区二区动漫| 在线观看不卡的av| 亚洲天堂免费在线观看视频| 怡红院亚洲色图| 亚洲不卡av不卡一区二区| 亚洲free性xxxx护士hd| 亚洲色图美国十次| 亚洲大胆人体视频| 天天综合天天干| 国产亚洲一区二区在线观看| 九一精品在线观看| 欧美高清在线| 99久久99久久| 午夜影院在线观看国产主播| 亚洲欧美制服另类日韩| 国产精品sm调教免费专区| 亚洲欧洲另类国产综合| 丰满饥渴老女人hd| 91久久视频| 欧美亚洲精品日韩| 永久免费观看精品视频| 久久久久中文字幕| 精华区一区二区三区| 欧美日韩和欧美的一区二区| 国内偷拍精品视频| 97久久精品人人爽人人爽蜜臀| 日日碰狠狠躁久久躁婷婷| 国产精品88久久久久久| 国产精品一区二区三区在线观| 一个人看的www视频在线免费观看| 国产一区二区日韩| 午夜精品久久久久久久第一页按摩| 精品国产成人av| 日本不卡一区视频| 高清不卡在线观看av| 黄色片久久久久| **女人18毛片一区二区| 九色视频成人porny| 欧美亚洲人成在线| 久久免费视频网| 亚洲免费视频一区二区三区| 精品女同一区二区| 中文字幕无线码一区| 性感美女极品91精品| 日韩不卡av在线| 99免费精品视频| 99re精彩视频| 亚洲一区观看| 视色,视色影院,视色影库,视色网 日韩精品福利片午夜免费观看 | 成年人在线观看| 欧美精品一区男女天堂| 亚洲视频中文字幕在线观看| 欧美性黄网官网| 妺妺窝人体色www在线下载| 日本一二三不卡| 7788色淫网站小说| 国产一区二区三区在线观看免费| 国产精品后入内射日本在线观看| 亚洲色图二区| 久久中文字幕视频| 欧美肉大捧一进一出免费视频| 日日夜夜免费精品视频| 日韩极品视频在线观看| 日韩在线综合| 欧美一区亚洲二区| 国产伦理久久久久久妇女 | 91片黄在线观看| 中文字幕 欧美 日韩| 老鸭窝一区二区久久精品| 成人一级片网站| 在线成人欧美| 国产亚洲精品久久久久久久| 我不卡伦不卡影院| 午夜精品美女久久久久av福利| 香蕉久久夜色精品国产使用方法| 丁香五月网久久综合| 国产精品一区二区三区www| 国产精品自产拍在线观看| 色婷婷综合久久久中字幕精品久久| 久久久久久久久久久人体| av在线播放国产| 精品久久久av| 精品国产99久久久久久| 久久久成人精品| 欧美成人三区| www.亚洲一区| 免费在线看黄网站| 日韩在线视频国产| 亚洲成人三级| 久久精品视频在线播放| 欧洲美女少妇精品| 日韩在线中文字幕| 欧美jizz18性欧美| 日韩有码片在线观看| 欧美性猛交xxx乱大交3蜜桃| 日韩中文在线不卡| 免费观看在线午夜影视| 不卡中文字幕av| av网站在线看| 久久全球大尺度高清视频| 超清av在线| 欧美性受xxx| 亚洲成人短视频| 国产精品日本精品| 91精品一久久香蕉国产线看观看| 国产一区二区色| 国产一区二区三区| 国产九区一区在线| 在线日本制服中文欧美| 午夜精品区一区二区三| 2023国产精品久久久精品双| 欧美日韩午夜爽爽| 亚洲美女一区| 日本xxxxxxx免费视频| 蜜臀av一区二区| 色姑娘综合天天| av男人天堂一区| 国产传媒在线看| 亚洲色图一区二区三区| 国产乱码久久久久久| 色婷婷久久久亚洲一区二区三区 | 国内视频一区二区| 国产精品一区二区av日韩在线| 一区不卡视频| 影音国产精品| 91视频免费版污| 国产精品资源在线| 精品人妻一区二区三区视频| 国产精品灌醉下药二区| 国产第一页在线播放| 欧美亚洲免费在线一区| 国产美女免费视频| 国产视频一区在线| 精品国产99久久久久久| 538国产精品一区二区免费视频| 国产精品伦一区二区| 国产精品精品软件视频| 欧美日韩在线二区| 成人午夜视频在线观看免费| 免费观看成人av| 成年女人免费视频| 国产精品久久午夜夜伦鲁鲁| 国产污视频在线看| 欧美日韩精品欧美日韩精品一 | 草莓视频18免费观看| 欧美一级理论片| 国产在线色视频| 欧美黑人狂野猛交老妇| 国产成人精品一区二区三区视频| 国产精品swag| 久久综合av| 欧美日韩中文在线视频| 国产黑丝在线一区二区三区| av网站免费在线看| 性久久久久久久久久久久| 国产精品久久久久久久久久久久久久久久久久 | 成人黄色一区二区| 成人黄色网址在线观看| 日韩三级在线观看视频| 欧美性xxxxx极品少妇| 日韩在线观看视频一区二区三区| 日韩一区二区欧美| se69色成人网wwwsex| 久久www免费人成精品| 永久亚洲成a人片777777| 欧美一级特黄a| 久久只精品国产| 日韩三级小视频| 日韩视频不卡中文| 美女黄视频在线观看| 国产精品久久77777| 性欧美xxxx免费岛国不卡电影| 国产一级大片免费看| 人妖欧美一区二区| 中文字幕有码在线播放| 色综合av在线| 日韩私人影院| 97热在线精品视频在线观看| 一区二区三区亚洲变态调教大结局| 亚洲欧美日产图| 日本视频一区二区三区| 无码一区二区三区在线| 黑人巨大精品欧美一区免费视频| 黑人精品一区二区| 欧美精品成人91久久久久久久| 日韩综合一区二区三区| a级片一区二区| 国产不卡视频一区| 久久精品视频日本| 精品捆绑美女sm三区| 欧美24videosex性欧美| 国产精品久久久对白| 黄色工厂这里只有精品| 日本泡妞xxxx免费视频软件| 曰韩精品一区二区| 蜜桃91麻豆精品一二三区| 欧美激情一区二区三级高清视频| 一区二区三区国产好| 无码熟妇人妻av在线电影| 波多野结衣一区二区三区| 日韩视频免费观看高清| 国产视频在线观看一区二区| 欧美电影h版| 亚洲视频精品一区| 国产尤物一区二区在线| 国产这里有精品| 日韩av一卡二卡| 成人日韩在线| 最新精品视频| 成人免费看黄yyy456| 免费av网站在线| 中文字幕不卡av| 国产精品成人3p一区二区三区| avav在线播放| 久久一区二区三区国产精品| 中文字幕 人妻熟女| 久久久国产成人精品| 红杏aⅴ成人免费视频| 亚洲熟妇av一区二区三区漫画| 欧美韩国一区二区| 国产chinasex对白videos麻豆| 欧美激情一区二区三区高清视频 | 国产精品中文字幕日韩精品| 日本熟妇乱子伦xxxx| 国产亚洲精品久久久优势| 涩涩涩久久久成人精品| 缅甸午夜性猛交xxxx| 国产午夜久久久久| 国内老熟妇对白hdxxxx| 9.1国产丝袜在线观看| 色综合五月天| 看全色黄大色黄女片18| 在线观看视频91| 欧美巨大xxxx做受沙滩| 日韩av一区二区三区在线| 国产在线精品不卡| 毛片视频网站在线观看| www.亚洲天堂| 亚洲精华一区二区三区| 日本高清一区二区视频| 丁香五六月婷婷久久激情| 超碰超碰在线| 清纯唯美一区二区三区| 福利91精品一区二区三区| 中文字幕一区二区在线视频| 久久久久久久久久久久av|