jQuery - พื้นฐาน

jQuery เป็นเฟรมเวิร์กที่สร้างขึ้นโดยใช้ความสามารถของ JavaScript ดังนั้นคุณสามารถใช้ฟังก์ชันและความสามารถอื่น ๆ ทั้งหมดที่มีใน JavaScript บทนี้จะอธิบายแนวคิดพื้นฐานส่วนใหญ่ แต่ใช้บ่อยใน jQuery

สตริง

สตริงใน JavaScript เป็นอ็อบเจ็กต์ที่ไม่เปลี่ยนรูปซึ่งไม่มีอักขระหนึ่งตัวหรือหลายตัว ต่อไปนี้เป็นตัวอย่างที่ถูกต้องของสตริง JavaScript -

"This is JavaScript String"
'This is JavaScript String'
'This is "really" a JavaScript String'
"This is 'really' a JavaScript String"

ตัวเลข

ตัวเลขใน JavaScript คือค่า IEEE 754 รูปแบบ 64 บิตที่มีความแม่นยำสองเท่า พวกมันไม่เปลี่ยนรูปเช่นเดียวกับสตริง ต่อไปนี้เป็นตัวอย่างที่ถูกต้องของ JavaScript Numbers -

5350
120.27
0.26

บูลีน

บูลีนใน JavaScript สามารถเป็นได้ true หรือ false. หากตัวเลขเป็นศูนย์จะมีค่าเริ่มต้นเป็นเท็จ หากสตริงว่างมีค่าเริ่มต้นเป็นเท็จ

ต่อไปนี้เป็นตัวอย่างที่ถูกต้องของ JavaScript Boolean -

true      // true
false     // false
0         // false
1         // true
""        // false
"hello"   // true

วัตถุ

JavaScript รองรับแนวคิด Object ได้เป็นอย่างดี คุณสามารถสร้างวัตถุโดยใช้ตัวอักษรของวัตถุได้ดังนี้ -

var emp = {
   name: "Zara",
   age: 10
};

คุณสามารถเขียนและอ่านคุณสมบัติของวัตถุโดยใช้สัญกรณ์จุดดังนี้ -

// Getting object properties
emp.name  // ==> Zara
emp.age   // ==> 10

// Setting object properties
emp.name = "Daisy"  // <== Daisy
emp.age  =  20      // <== 20

อาร์เรย์

คุณสามารถกำหนดอาร์เรย์โดยใช้ลิเทอรัลอาร์เรย์ดังนี้ -

var x = [];
var y = [1, 2, 3, 4, 5];

อาร์เรย์มีไฟล์ length คุณสมบัติที่มีประโยชน์สำหรับการทำซ้ำ -

var x = [1, 2, 3, 4, 5];

for (var i = 0; i < x.length; i++) {
   // Do something with x[i]
}

ฟังก์ชั่น

ฟังก์ชันใน JavaScript สามารถตั้งชื่อหรือไม่ระบุชื่อก็ได้ ฟังก์ชันที่ตั้งชื่อสามารถกำหนดได้โดยใช้คำสำคัญของฟังก์ชันดังนี้ -

function named(){
   // do some stuff here
}

ฟังก์ชันนิรนามสามารถกำหนดได้ในลักษณะเดียวกันกับฟังก์ชันปกติ แต่จะไม่มีชื่อใด ๆ

ฟังก์ชันนิรนามสามารถกำหนดให้กับตัวแปรหรือส่งผ่านไปยังวิธีการดังที่แสดงด้านล่าง

var handler = function (){
   // do some stuff here
}

JQuery ใช้ฟังก์ชันที่ไม่ระบุชื่อบ่อยมากดังนี้ -

$(document).ready(function(){
   // do some stuff here
});

อาร์กิวเมนต์

อาร์กิวเมนต์ตัวแปร JavaScript คืออาร์เรย์ชนิดหนึ่งที่มีคุณสมบัติความยาว ตัวอย่างต่อไปนี้อธิบายได้ดีมาก -

function func(x){
   console.log(typeof x, arguments.length);
}

func();                //==> "undefined", 0
func(1);               //==> "number", 1
func("1", "2", "3");   //==> "string", 3

วัตถุอาร์กิวเมนต์ยังมีคุณสมบัติcalleeซึ่งหมายถึงฟังก์ชันที่คุณอยู่ภายใน ตัวอย่างเช่น -

function func() {
   return arguments.callee; 
}

func();                // ==> func

บริบท

คำหลักที่มีชื่อเสียงของ JavaScript thisอ้างถึงบริบทปัจจุบันเสมอ ภายในฟังก์ชันthis บริบทสามารถเปลี่ยนแปลงได้ขึ้นอยู่กับวิธีการเรียกใช้ฟังก์ชัน -

$(document).ready(function() {
   // this refers to window.document
});

$("div").click(function() {
   // this refers to a div DOM element
});

คุณสามารถระบุบริบทสำหรับการเรียกใช้ฟังก์ชันโดยใช้วิธีการในตัวฟังก์ชัน call() และ apply() วิธีการ

ความแตกต่างระหว่างพวกเขาคือวิธีที่พวกเขาส่งผ่านข้อโต้แย้ง การโทรส่งผ่านอาร์กิวเมนต์ทั้งหมดเป็นอาร์กิวเมนต์ของฟังก์ชันในขณะที่ใช้ยอมรับอาร์เรย์เป็นอาร์กิวเมนต์

function scope() {
   console.log(this, arguments.length);
}

scope() // window, 0
scope.call("foobar", [1,2]);  //==> "foobar", 1
scope.apply("foobar", [1,2]); //==> "foobar", 2

ขอบเขต

ขอบเขตของตัวแปรคือขอบเขตของโปรแกรมของคุณที่กำหนดไว้ ตัวแปร JavaScript จะมีเพียงสองขอบเขต

  • Global Variables - ตัวแปรส่วนกลางมีขอบเขตทั่วโลกซึ่งหมายความว่ามีการกำหนดทุกที่ในโค้ด JavaScript ของคุณ

  • Local Variables- ตัวแปรโลคัลจะมองเห็นได้เฉพาะในฟังก์ชันที่กำหนดไว้ พารามิเตอร์ของฟังก์ชันจะอยู่ในพื้นที่ของฟังก์ชันนั้นเสมอ

ภายในเนื้อความของฟังก์ชันตัวแปรโลคัลจะมีความสำคัญเหนือตัวแปรส่วนกลางที่มีชื่อเดียวกัน -

var myVar = "global";     // ==> Declare a global variable

function ( ) {
   var myVar = "local";   // ==> Declare a local variable
   document.write(myVar); // ==> local
}

โทรกลับ

การเรียกกลับเป็นฟังก์ชัน JavaScript ธรรมดาที่ส่งผ่านไปยังเมธอดบางอย่างเป็นอาร์กิวเมนต์หรือตัวเลือก การเรียกกลับบางรายการเป็นเพียงเหตุการณ์ที่เรียกเพื่อให้ผู้ใช้มีโอกาสตอบสนองเมื่อมีการเรียกใช้สถานะบางอย่าง

ระบบเหตุการณ์ของ jQuery ใช้การเรียกกลับดังกล่าวทุกที่เช่น -

$("body").click(function(event) {
   console.log("clicked: " + event.target);
});

การเรียกกลับส่วนใหญ่ให้อาร์กิวเมนต์และบริบท ในตัวอย่างตัวจัดการเหตุการณ์การเรียกกลับจะถูกเรียกด้วยอาร์กิวเมนต์เดียวคือเหตุการณ์

จำเป็นต้องมีการเรียกกลับบางอย่างเพื่อส่งคืนบางสิ่งบางอย่างบางรายการกำหนดให้ค่าส่งคืนนั้นเป็นทางเลือก เพื่อป้องกันการส่งแบบฟอร์มตัวจัดการเหตุการณ์ที่ส่งสามารถส่งคืนเท็จได้ดังนี้ -

$("#myform").submit(function() {
   return false;
});

การปิด

การปิดถูกสร้างขึ้นเมื่อใดก็ตามที่มีการเข้าถึงตัวแปรที่กำหนดนอกขอบเขตปัจจุบันจากภายในขอบเขตภายในบางส่วน

ตัวอย่างต่อไปนี้แสดงให้เห็นว่าตัวแปร counter สามารถมองเห็นได้ภายในฟังก์ชันการสร้างการเพิ่มและการพิมพ์ แต่จะมองไม่เห็นภายนอก -

function create() {
   var counter = 0;
	
   return {
      increment: function() {
         counter++;
      },
	   print: function() {
         console.log(counter);
      }
   }
}

var c = create();
c.increment();
c.print();     // ==> 1

รูปแบบนี้ช่วยให้คุณสามารถสร้างวัตถุด้วยวิธีการที่ดำเนินการกับข้อมูลที่โลกภายนอกมองไม่เห็น ควรสังเกตว่าdata hiding เป็นพื้นฐานของการเขียนโปรแกรมเชิงวัตถุ

รูปแบบพร็อกซี

พร็อกซีคือวัตถุที่สามารถใช้เพื่อควบคุมการเข้าถึงวัตถุอื่น มันใช้อินเทอร์เฟซเดียวกับออบเจ็กต์อื่นและส่งต่อการเรียกใช้เมธอดใด ๆ ไปยังมัน วัตถุอื่น ๆ นี้มักเรียกว่าวัตถุจริง

พร็อกซีสามารถสร้างอินสแตนซ์แทนหัวเรื่องจริงนี้และอนุญาตให้เข้าถึงได้จากระยะไกล เราสามารถบันทึกเมธอด setArray ของ jQuery ในการปิดและเขียนทับได้ดังนี้ -

(function() {
   // log all calls to setArray
   var proxied = jQuery.fn.setArray;

   jQuery.fn.setArray = function() {
      console.log(this, arguments);
      return proxied.apply(this, arguments);
   };
	
})();

ด้านบนรวมโค้ดไว้ในฟังก์ชันเพื่อซ่อนตัวแปรพร็อกซี จากนั้นพร็อกซีจะบันทึกการโทรทั้งหมดไปยังเมธอดและมอบหมายการโทรไปยังเมธอดดั้งเดิม การใช้ใช้ (อาร์กิวเมนต์นี้) จะรับประกันได้ว่าผู้โทรจะไม่สามารถสังเกตเห็นความแตกต่างระหว่างวิธีดั้งเดิมและวิธีการพร็อกซี

ฟังก์ชั่นในตัว

JavaScript มาพร้อมกับชุดฟังก์ชันที่มีประโยชน์ในตัว วิธีการเหล่านี้สามารถใช้เพื่อจัดการกับสตริงตัวเลขและวันที่

ต่อไปนี้เป็นฟังก์ชัน JavaScript ที่สำคัญ -

ซีเนียร์ วิธีการและคำอธิบาย
1

charAt()

ส่งกลับอักขระที่ดัชนีที่ระบุ

2

concat()

รวมข้อความของสองสตริงและส่งคืนสตริงใหม่

3

forEach()

เรียกใช้ฟังก์ชันสำหรับแต่ละองค์ประกอบในอาร์เรย์

4

indexOf()

ส่งคืนดัชนีภายในอ็อบเจ็กต์สตริงการเรียกของการเกิดขึ้นครั้งแรกของค่าที่ระบุหรือ -1 หากไม่พบ

5

length()

ส่งกลับความยาวของสตริง

6

pop()

ลบองค์ประกอบสุดท้ายออกจากอาร์เรย์และส่งคืนองค์ประกอบนั้น

7

push()

เพิ่มองค์ประกอบอย่างน้อยหนึ่งรายการที่ส่วนท้ายของอาร์เรย์และส่งกลับความยาวใหม่ของอาร์เรย์

8

reverse()

กลับลำดับขององค์ประกอบของอาร์เรย์ - อันแรกกลายเป็นลำดับสุดท้ายและสุดท้ายจะกลายเป็นลำดับแรก

9

sort()

จัดเรียงองค์ประกอบของอาร์เรย์

10

substr()

ส่งคืนอักขระในสตริงที่ขึ้นต้นตำแหน่งที่ระบุผ่านจำนวนอักขระที่ระบุ

11

toLowerCase()

ส่งคืนค่าสตริงการโทรที่แปลงเป็นตัวพิมพ์เล็ก

12

toString()

ส่งกลับการแสดงสตริงของค่าของตัวเลข

13

toUpperCase()

ส่งกลับค่าสตริงการโทรที่แปลงเป็นตัวพิมพ์ใหญ่

Document Object Model

Document Object Model คือโครงสร้างต้นไม้ขององค์ประกอบต่างๆของ HTML ดังนี้ -

<html>
   <head>
      <title>The jQuery Example</title>
   </head>
	
   <body>
      <div>
         <p>This is a paragraph.</p>
         <p>This is second paragraph.</p>
         <p>This is third paragraph.</p>
      </div>
   </body>
</html>

สิ่งนี้จะให้ผลลัพธ์ดังต่อไปนี้ -

ต่อไปนี้เป็นประเด็นสำคัญเกี่ยวกับโครงสร้างต้นไม้ข้างต้น -

  • <html> เป็นบรรพบุรุษขององค์ประกอบอื่น ๆ ทั้งหมด กล่าวอีกนัยหนึ่งองค์ประกอบอื่น ๆ ทั้งหมดเป็นลูกหลานของ <html>

  • องค์ประกอบ <head> และ <body> ไม่ได้เป็นเพียงลูกหลานเท่านั้น แต่ยังเป็นลูก ๆ ของ <html> ด้วย

  • ในทำนองเดียวกันนอกจากจะเป็นบรรพบุรุษของ <head> และ <body> แล้ว <html> ยังเป็นพ่อแม่ของพวกเขาด้วย

  • องค์ประกอบ <p> คือลูก ๆ (และลูกหลาน) ของ <div> ลูกหลานของ <body> และ <html> และพี่น้องของกันและกัน <p> องค์ประกอบ

ในขณะที่การเรียนรู้แนวคิด jQuery ก็จะเป็นประโยชน์ที่จะมีการทำความเข้าใจเกี่ยวกับ DOM ถ้าคุณไม่ได้ตระหนักถึง DOM แล้วฉันขอแนะนำให้ไปผ่านการกวดวิชาที่เรียบง่ายของเราในDOM กวดวิชา