實(shí)話說學(xué)習(xí)是沒有捷徑的,最多也就是有一些學(xué)習(xí)的方法和技巧。關(guān)于學(xué)習(xí)JavaScript也就是js我分享一下我這個菜鳥的學(xué)習(xí)方法,只是個人的一些看法,不喜勿噴。
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信平臺小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了香河免費(fèi)建站歡迎大家使用!
1、基礎(chǔ)要學(xué)的好
學(xué)過js的都是知道的,js的一些基礎(chǔ)的語法和一些變成語言是不一樣的,所以需要額外的注意一些基礎(chǔ)的語法,舉例來說:作用域,一般的編程語言都是全局變量函數(shù)外有效,函數(shù)內(nèi)的變量函數(shù)內(nèi)有效,而js是不一樣的,js的全局變量函數(shù)外和函數(shù)內(nèi)都有效,函數(shù)內(nèi)的函數(shù)只函數(shù)內(nèi)有效。還有js是基于對象的語言,但是為了支持面向?qū)ο蟮木幊趟枷?,js使用函數(shù)來模擬類或者是對象的概念,這些都是比較難理解的,含有一些js的地層?xùn)|西如原型鏈、上下文等也是非常的不好理解,這就需要基礎(chǔ)的知識一定要扎實(shí)才能行。
2、多練習(xí)和實(shí)踐
其實(shí)學(xué)習(xí)編程都是這樣的,多動手多思考是學(xué)習(xí)編程語言的最好辦法,很多東西看起來簡單但是做起來就非常難了,解決的方法是學(xué)習(xí)js要和做網(wǎng)頁特效聯(lián)系起來,畢竟js的一個很大的應(yīng)用方向就是實(shí)現(xiàn)網(wǎng)頁的效果和一些交互,所以學(xué)習(xí)基礎(chǔ)的同時要試著使用原生的js代碼來實(shí)現(xiàn)一些網(wǎng)頁特效,從中可以學(xué)到j(luò)s這門語言的博大精深。
2、學(xué)習(xí)面向?qū)ο蟮木幊趟枷?/p>
雖然js對于面向?qū)ο缶幊痰闹С植皇呛芡昝溃且恍﹋s的大神使用了一些很多的方法,如構(gòu)造函數(shù)等模擬了一些比較完整的面向?qū)ο缶幊?,所以難點(diǎn)也出來了,那就是js的面向?qū)ο笠绕渌恼Z言復(fù)雜難理解。
4、學(xué)習(xí)js的一些框架
使用原生的js進(jìn)行開發(fā)太難了,但是我們可以通過js的框架來解決這個問題,基礎(chǔ)的框架如jQuery,還有比較高級的框架如angularjs都是很不錯的東西,只是js原生學(xué)的好,這些框架也就比較好理解了
ECMAScript、DOM、BOM
JavaScript的三大組成部分是:
1、ECMAScript:JavaScript的核心,描述了語言的基本語法(var、for、if、array等)和數(shù)據(jù)類型(數(shù)字、字符串、布爾、函數(shù)、對象(obj、[]、{}、null)、未定義),ECMAScript是一套標(biāo)準(zhǔn),定義了一種語言(比如JS)是什么樣子。
2、文檔對象模型(DOM):DOM(文檔對象模型)是 HTML 和 XML 的應(yīng)用程序接口(API)。DOM 將把整個頁面規(guī)劃成由節(jié)點(diǎn)層級構(gòu)成的文檔。HTML 或 XML 頁面的每個部分都是一個節(jié)點(diǎn)的衍生物。請考慮下面的 HTML 頁面:
html
head
titleSample Page/title
/head
body
phello world!/p
/body
/html
這段代碼可以用 DOM 繪制成一個節(jié)點(diǎn)層次圖:DOM 通過創(chuàng)建樹來表示文檔,從而使開發(fā)者對文檔的內(nèi)容和結(jié)構(gòu)具有空前的控制力。用 DOM API 可以輕松地刪除、添加和替換節(jié)點(diǎn)(getElementById、childNodes、appendChild、 innerHTML)。
3、瀏覽器對象模型(BOM)對瀏覽器窗口進(jìn)行訪問和操作。例如彈出新的瀏覽器窗口,移動、改變和關(guān)閉瀏覽器窗口,提供詳細(xì)的網(wǎng)絡(luò)瀏覽器信息(navigator object),詳細(xì)的頁面信息(location object),詳細(xì)的用戶屏幕分辨率的信息(screen object),對cookies的支持等等。
o 是 對象 對象用法跟 數(shù)組差不多
比如 var o = {'a':10 , 'b': 20};
可以 alert( o['a'] ); //10
比如
var o = {'a':10 , 'b': 20}; //這個就是 對象定義 {屬性:值 , 屬性:值 , 屬性:值}
var a = ['a', 'b', 'c']; //這個是 數(shù)組
var i = 1;
這個時候 a[i] 是 字符 b
那么 o[a[i]] 就等于 o['b'] 也就是 20了
-----
比如
var o = {'a':10, 'b': 20, ‘c’:[3,6,9] }; // o是對象 有 3個屬性 第3個屬性c 本身又是 數(shù)組
var a = ['a', 'b', 'c'];
var i = 2;
var j = 1 ;
那么 o[a[i]] 等于 o[a[2]] 等于 o['c'] 就是 那個 [3,6,9]數(shù)組了
那么 o[a[i]][j] 就 等于 o['c'][j] 等于 o['c'][1] 等于 6
你理解錯誤了,輸入結(jié)果是由alert進(jìn)行的一個全局變量的輸出,也就是說alert(msg)中的msg變遠(yuǎn)是全局變量.
而在第一個例子中,由于show是引用了全局變量,并將全局變量的值更改為"局部變量",也就是說show函數(shù)在執(zhí)行時并沒有開辟新的變量,而是將全局變量的值更改了,所以顯示的是"局部變量",但msg卻不是一個局部變量,不能做為局部變量去理解的.
在第二個例子中,由于使用了var msg,在JS或是C中都是這樣的處理的,而不是不同于C,var 表示開辟新的內(nèi)存空間,這里會出現(xiàn)兩個msg變量,但是你別忘記了,show函數(shù)內(nèi)部的msg當(dāng)show函數(shù)執(zhí)行完畢返回到主程序中時,這個局部變量已經(jīng)不存在了.而alert(msg)顯示的仍然是主程序中的變量,當(dāng)然,show函數(shù)的變量不會了生任何的覆蓋的.所以會顯示出”全局變量”.
也就是說,兩次顯示的都是全局變量的值,雖然值有改變的.所以我想你可能將第一個變量想成了局部變量的,所以你錯了!
但是二樓,JS與C同屬于EMCA-262語言核心,在這一點(diǎn)上有什么區(qū)別?
我給樓主一個例子,樓主可以看一下:
script
var msg ="全局變量";//開辟全局變量
function show(){
var msg="局部變量";
alert(msg);//此處輸出的是局部變量,因?yàn)檫@些函數(shù)體內(nèi)如果有同名的全局變量昌被屏掉了.
}
/script
也就是說只有在我的這種情況是輸出的局部變量,而在你的兩個例子中由于alert()名是在主程序中,所以輸出都是全局變量的!只不過是全局變量與局部變量的值有沒有被覆蓋而已.當(dāng)你看到它輸入出的值是”局部變量”時,并不表示他是局部變量.變量的作用域與變量的值完全是兩碼事,不可混為一談!
我的例子與第二個例子做一下比較,你的理解會更深刻的.這種情況,如果輸入的是”全局變量”時才是全局變量,輸出的是”局部變量”時才是局部變量!想一想為什么吧!
JavaScript簡稱js,是一種基于對象和事件驅(qū)動并具有相對安全性的客戶端腳本語言。
JavaScript同時也是一種廣泛用于客戶端Web開發(fā)的腳本語言,常用來給HTML網(wǎng)頁添加動態(tài)功能,比如響應(yīng)用戶的各種操作。它最初由網(wǎng)景公司(Netscape)的Brendan Eich設(shè)計(jì),是一種動態(tài)、弱類型、基于原型的語言,內(nèi)置支持類。
特點(diǎn)
1、JavaScript可以創(chuàng)建活躍的用戶界面,當(dāng)用戶在頁面間導(dǎo)航時向他們反饋。
2、使用JavaScript來確保用戶以表單形式輸入有效的信息,這可以節(jié)省業(yè)務(wù)時間和開支。
3、JavaScript還可以處理表單,設(shè)置cookie,即時構(gòu)建HTML頁面以及創(chuàng)建基于Web的應(yīng)用程序。
4、使用JavaScript,根據(jù)用戶的操作可以創(chuàng)建定制的HTML頁面。