Bài giảng JavaScript - Bài 7 Thư viện jQuery và thư viện jQuery UI

Thư viện là kho lưu trữ mã cho các chức năng thông dụng. Bạn cũng có thể tự tạo thư viện cho riêng mình hoặc để chia sẻ Có rất nhiều thư viện cho javascript. Mỗi thư viện có một điểm mạnh riêng. jQuery là một thư viện thông dụng và dễ sử dụng Điểm nổi bật của jQuery là tìm (query) các element và thực hiện hành động lên các element đó jQuery cung cấp các cách khác nhau để tìm elemet như tìm bằng id, lớp, loại, hệ thống phân cấp, vị trí, attribute

pdf53 trang | Chia sẻ: truongthinh92 | Lượt xem: 1915 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Bài giảng JavaScript - Bài 7 Thư viện jQuery và thư viện jQuery UI, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Bài 7: Thư viện jQuery và thư viện jQuery UI Hệ thống bài cũ Viết mã tạo các hiệu ứng Hiệu ứng Image Rollover Hiệu ứng SlideShow Thao tác với các điều khiển SelectBox CheckBox RadioButton Form Kiểm tra tính hợp lệ cho Form CSS trong JavaScript Thư viện jQuery và jQuery UI 2 Mục tiêu bài học Thự viện và cách tạo thư viện Thư viện JavaScript Sử dụng thư viện jQuery Sử dụng jQuery để tạo hiệu ứng Hiệu ứng ẩn hiện Hiệu ứng mờ Hiệu ứng chuyển động Sử dụng thư viện jQuery UI Tạo tính năng kéo thả (drag and drop) Tạo menu chồng nhau Thư viện jQuery và jQuery UI 3 THƯ VIỆN JAVASCRIPT Lập trình hướng đối tượng và mô hình DOM 4 Thư viện Vấn đề nảy sinh Lập trình viên nhận thấy trong quá trình lập trình phải thực hiện lặp lại nhiều chức năng thông dụng Giải pháp Tạo một thư viện các đoạn mã thực hiện các chức năng thông dụng để chia sẻ chung Lập trình viên chia làm 2 hướng: Những chuyên gia nghiên cứu sâu về hệ thống để viết các đoạn mã tối ưu cho thư viện Các lập trình viên viết các ứng dụng sử dụng đoạn mã từ thư viện Ưu điểm giải pháp Lập trình trở nên dễ dàng hơn Tiết kiệm thời gian Thư viện ngày càng được tối ưu Thư viện jQuery và jQuery UI 5 Xây dựng thư viện JavaScript Có thể tự xây dựng thư viện cho cho riêng mình hoặc dùng để chia sẻ Thực hiện viết mã cho thư viện Viết mã thư viện trong một file .js Khi cần sử dụng thì tham chiếu đến file này Thư viện jQuery và jQuery UI 6 Demo xây dựng thư viện Viết mã cho thư viện trong file myLibrary.js Sử dụng đối tượng MyLibrary trong thư viện var MyAlert = {}; MyAlert.sendAlert = function(mesg) { alert(mesg); }; MyAlert.sendAlert("Xin chào, đây là thư viện của tôi"); Thư viện jQuery và jQuery UI 7 (Xem ví dụ My Library) Các thư viện của JavaScript Lập trình mất nhiều thời gian và công sức để làm cho trang web chạy giống nhau trên nhiều trình duyệt  Cần có những người nghiên cứu sâu về các trình duyệt, mã javascript để viết nên thư viện các chức năng thông dụng chạy tốt trên nhiều trình duyệt Có rất nhiều thư viện cho JavaScript, mỗi thư viện có một thế mạnh riêng Jquery (Tham khảo: Yahoo! User Interface (YUI, Tham khảo: MooTools (Tham khảo: Và các thư viện khác (Tham khảo: rks) Thư viện jQuery và jQuery UI 8 THƯ VIỆN JQuery Lập trình hướng đối tượng và mô hình DOM 9 jQuery jQuery là một thư viện JavaScript được ưa chuộng và dễ sử dụng Thư viện jQuery bao gồm 1 file JavaScript (Click vào đây để xem file) Thư viện jQuery và jQuery UI 10 Làm quen jQuery qua ví dụ đầu tiên Thư viện jQuery và jQuery UI 11 Nhấn vào đoạn văn bản thì đoạn văn bản biến mất Xem Vi du jQuery dau tien Làm quen jQuery qua ví dụ đầu tiên $(document).ready(function(){ $("p").click(function(){ $(this).hide(); }); }); Hay nhan vao toi, toi se bien mat!!! Tham chiếu đến thư viện Mã jQuery Thư viện jQuery và jQuery UI 12 Thêm thư viện vào trang web của bạn B1. Truy cập địa chỉ Thư viện jQuery và jQuery UI 13 Thêm thư viện vào trang web của bạn B2. Lựa chọn phiên bản để down. Có hai phiên bản Production: Dành cho người chỉ muốn sử dụng thư viện để viết các ứng dụng (Bạn nên down phiên bản này) Development: Dành cho người muốn phát triển các plug-in cho jQuery hoặc muốn nghiên cứu sâu hơn về jQuery Thư viện jQuery và jQuery UI 14 Thêm thư viện vào trang web B3. Down thư viện Trên Browser, vào File  Save Page As Để down thư viện. Lưu file thư viện vào cùng thư mục với trang web B4. Tham chiếu đến file thư viện (jquery-1.6.4.min.js ) Thư viện jQuery và jQuery UI 15 jQuery jQuery thực hiện tìm (query) đến các element của trang web và thực hiện các “hành động” lên chúng Cú pháp: $: Chỉ ra sử dụng thư viện jQuery selector: Chỉ ra các phần tử được chọn action: Chỉ ra các hành động được thực hiện lên các phần tử được chọn đó $(selector).action() Thư viện jQuery và jQuery UI 16 $("p").hide() $("div").show() Lựa chọn các element Lựa chọn element theo ID Lựa chọn element theo lớp Lựa chọn element theo loại Lựa chọn element theo hệ thống phân cấp Lựa chọn element theo vị trí Lựa chọn element theo attribute Thư viện jQuery và jQuery UI 17 Lựa chọn element theo ID Cú pháp Mã HTML Truy cập đến element có id là linkID Truy cập đến element có id là linkID $("#id_của_element") Link Thư viện jQuery và jQuery UI 18 getElementById("linkID") $("#linkID") $("a#linkID") Lựa chọn element theo lớp Cú pháp Mã HTML Chọn tất cả các element có tên lớp là link Chọn tất cả các element có tên lớp là link $(".tên_lớp") Link Thư viện jQuery và jQuery UI 19 $(".link") $(“a.link") Lựa chọn element theo loại Cú pháp Chọn tất cả các element div trên trang $("tên_thẻ_HTML") $("div") Thư viện jQuery và jQuery UI 20 Lựa chọn element theo hệ phân cấp Mã HTML Chọn tất cả các element nằm trong thẻ div Chọn tất cả các element nằm trong thẻ div divContent Google w3schools </body Thư viện jQuery và jQuery UI 21 $("div a") $(“#divContent a") Lựa chọn element theo vị trí Mã HTML Chọn element đầu tiên trong tài liệu Chọn element cuối cùng trong tài liệu Chọn element thứ hai trong tài liệu Chọn các element lẻ trong tài liệu Phần tử đầu tiên là 0 Đầu tiên Thứ hai Thứ ba $("p:first") Thư viện jQuery và jQuery UI 22 $("p:last") $("p")[1] $("p:odd") Lựa chọn element theo attribute Chọn tất cả các element có attribute href Chọn tất cả các element có attribute href Chọn tất cả các element với attribute href có giá trị là “#” Một số ký tự đặc biệt $("[href]") $("a[href]") $("a[href = '#']") Thư viện jQuery và jQuery UI 23 Cú pháp Giải thích attributeName*=value chọn các element mà giá trị của attribute chứa value attributeName~=value chọn các element mà giá trị attribute bằng value attributeName!=value chọn các element mà giá trị attribute không bằng value hoặc không có attribute đó attributeName$=value chọn các element mà giá trị attribute kết thúc bằng value attributeName^=value chọn các element mà giá trị attriubte bắt đầu bằng value Thực hiện hành động Sau khi tìm được các element, điều quan trọng là thực hiện các hành động lên các element đó jQuery cung cấp các phương thức để thực hiện các hành động Các phương thức xử lý sự kiện Phương thức làm việc với css Các phương thức để thực hiện duyệt qua các element Các phương thức để tạo các hiệu ứng Thư viện jQuery và jQuery UI 24 Xử lý sự kiện cho các element jQuery hỗ trợ hồi đáp lại các sự kiện như nhấn chuột, submit form, gõ phím Sử dụng xử lý sự kiện với jQuery tối ưu hơn so với cách thông thường bởi nó ứng xử giống nhau đối với các trình duyệt Có hai cách khác nhau để xử lý sự kiện Sử dụng hàm bind() để gán xử lý sự kiện cho element Gọi trực tiếp xử lý sự kiện từ element Thư viện jQuery và jQuery UI 25 Truy cập trang web để hiểu thêm về xử lý sự kiện trên jQuery Sử dụng hàm bind() Cú pháp event: tên sự kiện data: dữ liệu truyền vào handler: xử lý sự kiện Ví dụ $(selector).bind(event, data, handler) Nhấn vào đây $("#link").bind("click", function() { alert("Bạn vừa nhấn vào link"); }); Thư viện jQuery và jQuery UI 26 Sử dụng hàm bind() jQuery hỗ trợ những sự kiện sau với hàm bind() beforeunload focusin mousedown resize blur focusout mouseenter scroll change hover mouseleave select click keydown mousemove submit dbclick keypress mouseout toggle error keyup mouseover unload focus load mouseup Thư viện jQuery và jQuery UI 27 Truy cập trực tiếp đến xử lý sự kiện Bạn có thể truy cập trực tiếp đến xử lý sự kiện Nhấn vào đây $("#link").click(function() { alert("Bạn vừa nhấn vào link"); }); Thư viện jQuery và jQuery UI 28 Làm việc với CSS jQuery hỗ trợ phương thức css() để thay đổi các thuộc tính css cho các element HTML Cú pháp Ví dụ $(selector).css("tên_thuộc_tính", "giá_trị thuộc_tính") Hi there!!! $("p").click(function() { $(this).css("color", "red"); }); Thư viện jQuery và jQuery UI 29 Xem Hanh dong\CSS Duyệt qua các element jQuery cung cấp hàm .each() để duyệt qua một nhóm các element được chọn Cú pháp $(selector).each(function({ //Thực hiện lệnh })); Thư viện jQuery và jQuery UI 30 Truy cập trang web để hiểu thêm về xử lý sự kiện trên jQuery Demo duyệt qua các element Bài toán Tên SV Điểm Nguyễn Văn An 10 Nguyễn Mạnh Hưng 4 Nguyễn Thị Mai 5 Nguyễn Thị Nghọc 4 Thư viện jQuery và jQuery UI 31 Những SV đỗ được in đâm Demo duyệt qua các element $(".diem").each(function() { if ($(this).text() >= 5) { $(this).parent().css('font-weight', 'bold'); } }); Thư viện jQuery và jQuery UI 32 Các hiệu ứng jQuery cung cấp nhiều hiệu ứng Hiệu ứng ẩn, hiện và thay đổi trạng thái (Hide, Show và Toggle) Hiệu ứng làm mờ (Fade In và Fade Out) Hiệu ứng trượt (Sliding) Thư viện jQuery và jQuery UI 33 Truy cập trang web để biết thêm về các hiệu ứng mà jQuery cung cấp Hiệu ứng ẩn, hiện và thay đổi trạng thái jQuery cung cấp các phương thức để thực hiện hiệu ứng này show(): Hiển thị element hide(): Ẩn element toggle(): Thay đổi trạng thái của element (Đang ẩn thì hiện, đang hiện thì sẽ ẩn) Thư viện jQuery và jQuery UI 34 Demo ẩn đoạn văn bản Bài toán Yêu cầu: Click vào Đoạn văn nào thì đoạn văn đó biến mất  Dùng phương thức hide() Đoạn văn 1 Đoạn văn 2 Đoạn văn 3 Đoạn văn 4 Thư viện jQuery và jQuery UI 35 Demo ẩn đoạn văn bản Mã jQuery Để tạo hiệu ứng ẩn từ từ, có thể thêm tham số thời gian vào phương thức hide (tính theo đơn vị milliseconds) $(".para").each(function() { $(this).click(function() { $(this).hide(); }); }); Thư viện jQuery và jQuery UI 36 $(".para").each(function() { $(this).click(function() { $(this).hide(500); }); }); Cũng có thể thêm tham số thời gian vào phương thức show và toggle Xem Hieu ung/hide Hiệu ứng mờ (Fade In và Fade Out) Fade In: Rõ dần cho đến khi xuất hiện Fade Out: Mờ dần cho đến khi biến mất $(".para").each(function() { $(this).click(function() { $(this). fadeOut(); }); }); Thư viện jQuery và jQuery UI 37 $(".para").each(function() { $(this).click(function() { $(this). fadeOut(1000); }); }); Truy cập trang web để hiểu thêm về hiệu ứng fade Xem Hieu ung/fade Hiệu ứng trượt (Sliding) slideUp(): Trượt lên trên và biến mất slideDown(): Trượt xuống dưới và xuất hiện $(".para").each(function() { $(this).click(function() { $(this).slideUp(); }); }); Thư viện jQuery và jQuery UI 38 $(".para").each(function() { $(this).click(function() { $(this).slideUp(1000); }); }); Xem Hieu ung/slide THƯ VIỆN JQuery UI Lập trình hướng đối tượng và mô hình DOM 39 jQuery UI Là một thư viện mở rộng cung cấp các tính năng cho giao diện như hộp chọn ngày, kéo thả, hay menu Thêm thư viện vào trang web Truy cập trang trang để down thư viện về sử dụng Có thể lựa chọn các thành phần cần thiết để down Hoặc down bản đầy đủ Giải nén thư viện và để cùng thư mục với trang web Lưu ý: để sử dụng jQuery UI, bạn phải thêm thư viện jQuery vào trang web của bạn Thư viện jQuery và jQuery UI 40 Truy cập trang web để xem các demo về các tính năng của jQuery Tính năng kéo thả (Drag and Drop) Phương thức draggable() để cho phép element được kéo Phương thức droppable() để xử lý sự kiện cho khi một element được thả vào element này Cú pháp $(selector).draggable() Thư viện jQuery và jQuery UI 41 $(selector).droppable()({ drop: function(event,ui){ //Thực hiện lệnh ở đây } }); Truy cập trang web để hiểu thêm về tính năng Drag and Drop Demo Drag and Drop #dragDiv { border: solid 1px black; padding: 3px; width: 100px; } #dropDiv { height: 200px; width: 200px; border: solid 1px black; background-color: #abacab; margin: 50px; } Hãy kéo tôi! Thả ở đây! Thư viện jQuery và jQuery UI 42 Xem Demo/jQuery UI/Drag and Drop Demo Drag and Drop $(document).ready(function() { $('#dragDiv').draggable(); $('#dropDiv').droppable({ drop: function(event, ui) { alert("Hộp văn bản bạn vừa drop: " + ui.draggable.text()); } }); }); Thư viện jQuery và jQuery UI 43 Demo Drag and Drop Thư viện jQuery và jQuery UI 44 Tạo menu chồng nhau jQuery UI hỗ trợ phương thức accordion() để tạo menu chồng nhau Thư viện jQuery và jQuery UI 45 Cách tạo menu chồng nhau Menu phải chứa các cặp header và div tương ứng Gọi phương thức accordion() để tạo menu First header First content Second header Second content Thư viện jQuery và jQuery UI 46 $(“#accordion“).accordion() Xem Demo/jQuery UI/accordion Demo tạo menu chồng nhau #menu { width: 250px; height: 250px; border: solid 2px black; padding: 3px; } .menuHead{ border: solid 1px black; background-color: #abacab; } .menuDiv { border-bottom: dotted 1px black; } Menu 1 Văn bản cho menu 1 Menu 2 Văn bản cho menu 2 Menu 3 Văn bản cho menu 3 Thư viện jQuery và jQuery UI 47 $('#menu').accordion(); Menu chồng nhau Thư viện jQuery và jQuery UI 48 SỬ DỤNG ĐOẠN MÃ CÓ SẴN Lập trình hướng đối tượng và mô hình DOM 49 Sử dụng các đoạn mã có sẵn Cộng đồng phát triển JavaScript khá lớn. Có rất nhiều đoạn code mẫu có thể sử dụng luôn, hoặc tùy chỉnh cho phù hợp với mục đích sử dụng Các đoạn mã mẫu thường là Tạo menu các loại Tạo hiệu ứng cho ảnh Tạo hiệu ứng cho văn bản Một số nguồn tham khảo code Thư viện jQuery và jQuery UI 50 Demo sử đoạn mã có sẵn trên trang Dynamic Drive Thư viện jQuery và jQuery UI 51 Thư viện các đoạn mã mẫu Thư viện là kho lưu trữ mã cho các chức năng thông dụng. Bạn cũng có thể tự tạo thư viện cho riêng mình hoặc để chia sẻ Có rất nhiều thư viện cho javascript. Mỗi thư viện có một điểm mạnh riêng. jQuery là một thư viện thông dụng và dễ sử dụng Điểm nổi bật của jQuery là tìm (query) các element và thực hiện hành động lên các element đó jQuery cung cấp các cách khác nhau để tìm elemet như tìm bằng id, lớp, loại, hệ thống phân cấp, vị trí, attribute Tổng kết bài học Thư viện jQuery và jQuery UI 52 jQuery cung cấp các hàm để thực hiện các hành động như hàm xử lý sự kiện, làm việc với css, duyệt qua các element và các hàm tạo các hiệu ứng jQuery UI là thư viện mở rộng, chứa các tính năng hỗ trợ cho giao diện như menu, kéo thả Ngoài ra lập trình viên có thể sử dụng hoặc tùy chỉnh các đoạn mã có sẵn để làm các chức năng mong muốn Tổng kết bài học Thư viện jQuery và jQuery UI 53

Các file đính kèm theo tài liệu này:

  • pdfslide_7_6815.pdf
Tài liệu liên quan