Hiển thị dữ liệu từ Google Sheets lên trang web¶
Google Sheets là công cụ phổ biến và thuận tiện để chia sẻ dữ liệu dạng bảng.
Bài viết này hướng dẫn cách lấy dữ liệu từ Google Sheets để hiển thị lên trang web.
Ý tưởng chính¶
Dùng Google Apps Script tạo một web app có chức năng sau:
- Lấy dữ liệu từ tập tin Google Sheets.
- Dựng bảng hiển thị dữ liệu.
Sau đó nhúng URL của web app vào trang web của mình.
Cách thực hiện¶
Tạo tập tin Google Sheets¶
Tập tin Google Sheets dùng để minh họa đặt tại đây.
Tập tin này chứa dữ liệu là các câu thần chú của Harry Potter.
Tạo Google Apps Script¶
Vào Google Drive > Nhấn nút New > More > Google Apps Script.
Tiếp theo:
- Ở cột bên trái, chọn <> Editor.
- Nhấn dấu + trong mục Services.
- Trong hộp thoại hiện ra, chọn mục Google Sheets API.
- Nhấn nút Add.
Viết mã cho tập tin Code.gs¶
Chọn tập tin Code.gs ở cột trái rồi sao chép đoạn mã dưới đây vào.
Thay đổi giá trị của các biến cho phù hợp. Chẳng hạn, ID của tập tin Google Sheets được lấy từ URL như hình sau.
Bạn nên thường xuyên nhấn Ctrl+S để lưu.
Viết mã cho tập tin JavaScript.html và Index.html¶
Tạo thêm hai tập tin là JavaScript.html và Index.html bằng cách:
- Trong mục Files ở cột trái, nhấn nút +.
- Chọn mục HTML
- Gõ tên tập tin, ví dụ JavaScript, không cần gõ phần tên mở rộng.
- Sao chép các đoạn mã dưới đây vào tập tin tương ứng.
Triển khai web app¶
Nhấn nút Deploy màu xanh ở góc trên bên phải, rồi chọn New Deployment.
Trong hộp thoại hiện ra:
- Gõ mô tả tùy ý vào ô Description.
- Chọn email của mình ở mục Execute as.
- Chọn Anyone ở mục còn lại.
- Nhấn Deploy.
Trong hộp thoại hiện ra tiếp theo, nhấn nút Authorize access để cấp quyền cho web app truy xuất vào Google Sheets. Chọn tài khoản Google của mình.
Trong cửa sổ tiếp theo:
- Nhấn Advanced (sau khi nhấn sẽ đổi thành Hide Advanced).
-
Nhấn tiếp link Go to Untitled project ở dưới cùng.
(Tên app hiện đang là Untitled project, bạn có thể thay đổi tùy ý vào lúc khác.)
Nhấn nút Allow.
Trong hộp thoại hiện ra, nhấn vào URL để xem kết quả.
Nếu tập tin Google Sheets có ô nào đó rỗng thì thông báo lỗi sẽ xuất hiện. Bạn cứ nhấn nút OK để bỏ qua và điều chỉnh sau.
Kết quả hiển thị như hình dưới đây:
Lưu ý
- Khi tạo lần đầu cũng như chạy thử lần đầu, bạn phải chọn Deploy > New deployment.
- Mỗi lần sửa mã lệnh, bạn có thể chạy thử bằng cách chọn Deploy > Test deployments.
- Khi hoàn tất, không còn điều chỉnh gì, bạn chọn lại Deploy > New deployment rồi chuyển sang bước 4.
Hiển thị lên trang web¶
Bạn chỉ cần nhúng URL của web wpp vào tag iframe
là xong.
your_web_page.html | |
---|---|
Lưu ý quan trọng
Kết quả hiển thị tại bước 3 là ở chế độ fullscreen, bảng hiển thị với kích thước nguyên vẹn. Nhưng khi nhúng vào web ở bước 4, bảng sẽ bị co giãn, và bạn phải tìm cách responsive cho bảng.
Tùy biến bảng¶
Bảng tạo ra trong bài này là nhờ công cụ DataTables. Bạn có thể tham khảo các vấn đề liên quan, kể cả responsive, tại DataTables | Table plug-in for jQuery.
Bạn có thể viết thêm các class CSS và bổ sung các tag HTML cần thiết trong tập tin Index.html.
Cũng tham khảo từ site DataTables, bạn có thể điều chỉnh các tham số trong các hàm của tập tin JavaScript.html.
Ví dụ:
Một số ô trong tập tin Google Sheets bị rỗng, khiến xuất hiện thông báo lỗi. Cách khắc phục là khởi tạo chuỗi rỗng làm mặc định.