CoffeeScript - jQuery

jQuery là một thư viện / khung công tác nhanh và ngắn gọn được xây dựng bằng JavaScript do John Resig tạo ra vào năm 2006 với phương châm tốt đẹp - Viết ít hơn, làm nhiều hơn.

jQuery đơn giản hóa việc duyệt qua tài liệu HTML, xử lý sự kiện, tạo hoạt ảnh và tương tác với Ajax để phát triển web nhanh chóng. Truy cập hướng dẫn jQuery của chúng tôi để biết về jQuery .

Chúng tôi cũng có thể sử dụng CoffeeScript để làm việc với jQuery. Chương này hướng dẫn bạn cách sử dụng CoffeeScript để làm việc với jQuery.

Sử dụng CoffeeScript với jQuery

Mặc dù jQuery giải quyết được các vấn đề của trình duyệt, nhưng việc sử dụng nó với JavaScript có một số phần không tốt sẽ có một chút vấn đề. Sử dụng CoffeeScript thay vì JavaScript là một ý tưởng tốt hơn.

Hãy ghi nhớ những điểm sau khi chuyển đổi sử dụng jQuery với CoffeeScript.

Các $biểu tượng cho biết mã jQuery trong ứng dụng của chúng tôi. Sử dụng điều này để tách mã jQuery khỏi ngôn ngữ kịch bản như được hiển thị bên dưới.

$(document).ready

Không cần sử dụng dấu ngoặc nhọn trong CoffeeScript ngoại trừ khi gọi các hàm với các tham số và xử lý mã không rõ ràng và chúng ta phải thay thế định nghĩa hàm function() có dấu mũi tên như hình bên dưới.

$(document).ready ->

Loại bỏ các câu lệnh trả về không cần thiết, vì CoffeeScript trả về ngầm định các câu lệnh theo đuôi của một hàm.

Thí dụ

Sau đây là mã JavaScript trong đó các phần tử <div> đang được chèn ngay trước phần tử được nhấp -

<html>

   <head>
      <title>The jQuery Example</title>
      <script type = "text/javascript" 
         src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
		
      <script type = "text/javascript" language = "javascript">
         $(document).ready(function() {
            $("div").click(function () {
               $(this).before('<div class="div"></div>' );
            });
         });
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
	
      <p>Click on any square below:</p>
      <span id = "result"> </span>
		
      <div class = "div" style = "background-color:blue;"></div>
      <div class = "div" style = "background-color:green;"></div>
      <div class = "div" style = "background-color:red;"></div>
		
   </body>
	
</html>

Bây giờ, chúng ta có thể chuyển đổi mã trên thành mã CoffeeScript như hình dưới đây

<html>

   <head>
      <title>The jQuery Example</title>
      <script type = "text/javascript"
         src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
      <script src="http://coffeescript.org/extras/coffee-script.js"></script>
	  
      <script type="text/coffeescript">
        $(document).ready ->
          $('div').click ->
            $(this).before '<div class="div"></div>'
            return
          return
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
	
      <p>Click on any square below:</p>
      <span id = "result"> </span>
		
      <div class = "div" style = "background-color:blue;"></div>
      <div class = "div" style = "background-color:green;"></div>
      <div class = "div" style = "background-color:red;"></div>
		
   </body>
	
</html>

Khi thực thi, điều này cung cấp cho bạn kết quả sau.

Gọi lại là gì?

Gọi lại là một hàm tương đương không đồng bộ cho một hàm. Một hàm gọi lại được gọi khi hoàn thành một nhiệm vụ nhất định. Node sử dụng nhiều lệnh gọi lại. Tất cả các API của Node đều được viết theo cách mà chúng hỗ trợ các lệnh gọi lại.

Ví dụ: một hàm đọc tệp có thể bắt đầu đọc tệp và trả lại điều khiển ngay lập tức về môi trường thực thi để lệnh tiếp theo có thể được thực thi. Khi quá trình nhập / xuất tệp hoàn tất, nó sẽ gọi hàm gọi lại trong khi chuyển hàm gọi lại, nội dung của tệp dưới dạng tham số. Vì vậy, không có việc chặn hoặc chờ đợi File I / O. Điều này làm cho Node.js có khả năng mở rộng cao, vì nó có thể xử lý số lượng yêu cầu cao mà không cần đợi bất kỳ hàm nào trả về kết quả.

Ví dụ về mã chặn

Tạo một tệp văn bản có tên input.txt có nội dung sau

Tutorials Point is giving self learning content 
to teach the world in simple and easy way!!!!!

Tạo tệp js có tên là main.js có mã sau:

var fs = require("fs");  
var data = fs.readFileSync('input.txt');  
console.log(data.toString()); 
console.log("Program Ended");

Bây giờ hãy chạy main.js để xem kết quả -

$ node main.js

Xác minh đầu ra.

Tutorials Point is giving self learning content 
to teach the world in simple and easy way!!!!! 
Program Ended

Ví dụ về mã không chặn

Tạo một tệp văn bản có tên input.txt có nội dung sau

Tutorials Point is giving self learning content 
to teach the world in simple and easy way!!!!!

Cập nhật tệp main.js để có mã sau:

var fs = require("fs");  
fs.readFile('input.txt', function (err, data) { 
  if (err) return console.error(err); 
    console.log(data.toString()); 
}); 
console.log("Program Ended");

Bây giờ hãy chạy main.js để xem kết quả -

$ node main.js

Xác minh đầu ra.

Program Ended 
Tutorials Point is giving self learning content 
to teach the world in simple and easy way!!!!!

Hai ví dụ này giải thích khái niệm blocking and non-blocking calls. Ví dụ đầu tiên cho thấy rằng chương trình sẽ chặn cho đến khi nó đọc tệp và sau đó, nó tiến hành kết thúc chương trình, trong khi trong ví dụ thứ hai, chương trình không đợi đọc tệp mà nó chỉ tiến hành in "Chương trình đã kết thúc".

Vì vậy, một chương trình chặn thực thi rất nhiều theo trình tự. Từ quan điểm lập trình, việc thực thi logic dễ dàng hơn nhưng các chương trình không chặn không thực thi theo trình tự. Trong trường hợp một chương trình cần sử dụng bất kỳ dữ liệu nào để được xử lý, thì nó nên được giữ trong cùng một khối để thực hiện tuần tự.