檢視 JavaScript 的原始碼
←
JavaScript
跳轉到:
導覽
、
搜尋
根據以下的原因,您並無權限去做編輯這個頁面:
您剛才的請求只有這個使用者組的使用者才能使用:
使用者
你可以檢視並複製本頁面的原始碼。
[[分類:程式語言]] ==基本語法== ===一、變數=== JavaScript變數命名規則 #變數可以由字母、數字、下劃線、美元符號($)組成 #變數必須以字母開頭,也能以 $ 和 _ 符號開頭(不過我們不推薦這麼做),但絕不能以數字開頭。 #變數名稱對大小寫敏感( y 和 Y 是不同的變數) ====(一)變數的宣告與作用域==== #let :只在被{ }包起來的區域中作用,不能在全域存取<br/>包含:if、else、 for、while、foreach…等等 #var :作用域是「函式作用域」,也就是在 function 內宣告的 var,要在該 function 內才有作用,以該 function 範圍為界線,在 function 外面的區域無法取用 #函式內未宣告:自己的 function 內如果找不到宣告,就會一層層往外找,直到全域變數為止。function 可以讀取外層已經宣告的變數, 但外層拿不到裡面宣告的變數。 <pre>var x = 1; var doSomeThing = function(y) { // 內部找不到 x 就會到外面找,直到全域變數為止。 // 都沒有就會報錯:ReferenceError: x is not defined return x + y; }; console.log( doSomeThing(50) ); // 51</pre> <pre>var x = 1; var doSomeThing = function(y) { x = 100; return x + y; }; console.log( doSomeThing(50) ); // 150 console.log( x ); // 100</pre> ====(二)測試變數是否存在==== '''typeof(變數)''' typeof(變數) === 'undefined' 表示變數尚未定義 <pre>if (typeof Vatiable1 === 'undefined' ) { 變數未定義 } else if (Vatiable1 === null){ 變數尚未賦值 } else { 有值的變數 }</pre> '''if (變數)''' 有六種情況為非:undefined、null、''、0、Nan 和 false,typeof 操作符只檢查 undefined 或 null。 ====(三)檢查元素是否在陣列中==== #陣列名.indexOf(元素):傳回元素是陣列的第幾個元素,不在則傳回 -1 #:indexOf(元素) #:indexOf(元素,搜尋起點的索引) #陣列名.includes(元素):傳回陣列是否包含元素,IE 以外的瀏覽器支援 #:includes(元素) #:includes(元素,搜尋起點的索引) #陣列名.find(元素代表變數 => (比對元素的條件)):找出陣列中第一個合條件的元素,IE 以外的瀏覽器支援 #:find(元素代表變數 => (對元素的比對條件)) #:find((元素代表變數,搜尋起點的索引) => (對元素的比對條件)) #陣列名.filter(元素代表變數 => (比對元素的條件)):找出陣列中所有合條件的元素,並形成新的陣列,所有瀏覽器皆支援 #:filter(元素代表變數 => (對元素的比對條件)) #:filter((元素代表變數,搜尋起點的索引) => (對元素的比對條件)) # for 迴圈 '''範例一''' <pre>let fruits = ["Apple", "Mango", "Pear", "Peach"]; console.log(fruits.indexOf("Pear")); // 輸出 2 console.log(fruits.indexOf("Tomato")); // 輸出 -1</pre> '''範例二''' <pre>let fruits = ["Apple", "Mango", "Pear", "Peach"]; console.log(fruits.includes("Pear")); // 輸出 true console.log(fruits.includes("Tomato")); // 輸出 false</pre> '''範例三''' <pre>let age = [21, 43, 23, 1, 34, 12, 8]; console.log(age.find(i => i > 20)); // 輸出 21 console.log(age.find(i => i > 21)); // 輸出 43</pre> '''範例四''' <pre>let age = [21, 43, 23, 1, 34, 12, 8]; console.log(age.filter(i => i > 20)); // 輸出 [21, 43, 23, 34] console.log(age.filter(i => i > 21)); // 輸出 [43, 23, 34]</pre> '''範例五''' <pre>for(let i=0; i<陣列名.length; i++){…}</pre> ===二、常數=== <pre>const Pi = 3.14159265 ;</pre> #宣告時就要同時賦值 #賦值後就不能被更動了 #作用域都只在 {…} 區塊內 ===三、函式=== ===四、運算=== ====(一)加法==== + 同時作為字串連接與數字相加 <pre>let a = 2; let b = 'hello'; console.log(a += 3); // addition // expected output: 5 console.log(b += ' world'); // concatenation // expected output: "hello world"</pre> ===五、函式=== ===六、控制結構=== ===七、選擇作用對象=== ====(一)getElementById('標籤Id')==== #派值給屬性:<br/>document.getElementById('標籤Id').textContent = value; ====(二)getElementsByName('標籤的name')[第幾]==== ====(三)querySelector('.Class名稱')==== #document.querySelector(".titleClass"):選擇單一元素,若多個元素均使用此 class ,只會取第一個元素內的資料。 #document.querySelectorAll(".titleClass em"):選擇使用此 class 的所有元素。<br/>document.querySelectorAll(".titleClass em").textContent = value;:對其屬性進行派值。 ==JSON== #JSON (JavaScript Object Notation,JavaScript 物件表示法)。 #以純文字為基礎,來儲存和交換簡單結構的輕量級「資料交換格式」(類似 XML)。 #JSON 比 XML(eXtensible Markup Language,可延伸標記式語言)更小、更快且更易解析。 ===格式=== JSON 可以包含物件(Object)或陣列(Array)資料。物件(Object)與陣列(Array)可互相包含,例如 {"array": [{"object": "object"}]} ====物件==== 如:{"name": value, "name": value},類似 PHP 中的字串索引陣列 #一個物件以 { 開始,並以 } 結束,來寫入資料。 #name 為字串,必須以 "" 括起來。 #name 與 value 之間使用 : 分隔。 #多個 name:value 之間使用 , 分隔。 ====陣列==== 如:[value, value] ,類似 PHP 中的註標索引陣列。 #一個陣列以 [ 開始,並以 ] 結束,來寫入資料。 #多個 value 之間使用 , 分隔。 ====物件和陣列值==== 如:{"array": ["string", 10, 1.0, -1, true, false, null]} #物件(Object):{}。 #陣列(Array):[]。 #字串(String):以 "" 括起來。 #數值(number):0-9 的數字組合(整數、小數或負數)。 #布林(boolean):true 或 false。 #空值(Null):null。 ===參考資料=== #[https://smalljacky.com/uncategorized/json-format-and-javascript/ JSON 格式與 JavaScript 解析教學範例] ==非同步請求== JavaScript 中的非同步請求有很多,如:Ajax、Fetch、setTimeout、Promise… ===一、Promise=== #Promise 是一個建構函式,原生的方法如下: #*Promise.all #*Promise.race #*Promise.resolve #*Promise.reject #用 Promise 建構函式 new 出的物件,如「var p=new Promise();」可以使用以下原生方法: #*p.then(); // Promise 回傳正確 #*p.catch(); // Promise 回傳失敗 #*p.finally(); // 非同步執行完畢(無論是否正確完成) #:這些方法則必須在新產生的物件下才能呼叫。 #Promise 在處理非同步的事件,非同步的過程中包含以下的進度狀態: #*pending:事件已經運行中,尚未取得結果 #*resolved:事件已經執行完畢且成功操作,回傳 resolve 的結果(該承諾已經被實現 fulfilled) #*rejected:事件已經執行完畢但操作失敗,回傳 rejected 的結果 #:進入 fulfilled 或 rejected 後就算完成不會再改變,Promise 中會使用 resolve 或 reject 回傳結果,並在調用時使用 then 或 catch 取得值。 #then、catch 都可以進行鏈接, then 能同時接收失敗的結果。 #最後可以使用 finally 來確認工作結束,finally 不帶有任何參數。如 Ajax 已經讀取完成,透過 finally 來關閉讀取。<br/><pre>promise(1).then(success => {console.log(success);}).finally(() => {console.log('done');})</pre> <img src='http://jendo.org/uploadFiles/學習資源/資訊/promise-pending.png' width='640'/>
返回到
JavaScript
。
導航
個人工具
登入
名字空間
頁面
討論
變換
檢視
閱讀
檢視原始碼
檢視歷史
動作
搜尋
導覽
首頁
近期變動
隨機頁面
使用說明
工具箱
連入頁面
相關頁面修訂記錄
特殊頁面
頁面資訊