- vừa được xem lúc

Chia sẻ một extension chrome tự viết để xem thông tin thời tiết

0 0 41

Người đăng: Hoàng Quang

Theo Viblo Asia

Xin chào tất cả các bạn.

Lâu rồi cũng không viết bài, hôm nay nghỉ lễ ở nhà tránh dịch nên mình lại lên đây, type vài dòng cho đỡ buồn.

Hiện tại, trong khi rảnh rỗi mình có viết một cái extension nho nhỏ để nghịch, nay lên đây chia sẻ lại mọi người tham khảo cho vui ?

Extension này mình viết dựa trên chức năng là sử dụng OpenWeatherMap API, chắc các bạn cũng biết đến thằng này rồi đúng không?

Dưới đây là giao diện cơ bản của nó, mình làm cũng rất đơn giản, chủ yếu là tạo một cái input để nhập địa phương để xem giá trị thời tiết thôi.

Đầu tiên, để biết được cấu trúc của một extension chrome nó hoạt động như thế nào thì chúng ta cần hiểu rõ về nó một tý. Các bạn có thể tham khảo thêm tại địa chỉ: https://developer.chrome.com/docs/extensions/mv3/getstarted/

nhưng cơ bản, nó chỉ bao gồm các file HTML, CSS và JS để hoạt động. Các bạn tham khảo chi tiết thêm ở link trên để rõ hơn về cấu trúc file.

Và mình sử dụng các file đó như sau, hiện tại trong cấu trúc mình làm sử dụng popup nên mình xử lý ở file popup.js, dưới đây là code của mình

var searchInput = document.getElementById('search-location');
var searchButton = document.getElementById('search-button');
var searchForm = document.getElementById('mw-search');
var api_key = 'API_KEY_HERE';
document.addEventListener('DOMContentLoaded', function() { searchForm.addEventListener('submit', function(e) { e.preventDefault(); var location_value = searchInput.value; if (location_value != '') { var location = location_value; } else { var location = 'Quang Tri'; } var xhttp = new XMLHttpRequest(); xhttp.open('GET', 'http://api.openweathermap.org/data/2.5/weather?q=' + location + ',VN&appid=' + api_key + '&units=metric&lang=vi', true); xhttp.send(); xhttp.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { var data = this.responseText; var data_parse = JSON.parse(data); //console.log(data_parse); var feels_like_value = data_parse.main.feels_like; var temp_value = data_parse.main.temp; var wind_value = (data_parse.wind.speed) * (60 * 60) / 1000; var sunrise_value = data_parse.sys.sunrise; var sunset_value = data_parse.sys.sunset; var date_sunrise = new Date(sunrise_value * 1000); var hours_sunrise = date_sunrise.getHours(); var minutes_sunrise = "0" + date_sunrise.getMinutes(); var seconds_sunrise = "0" + date_sunrise.getSeconds(); var formattedTime_sunrise = hours_sunrise + 'h' + minutes_sunrise.substr(-2); var date_sunset = new Date(sunset_value * 1000); var hours_sunset = date_sunset.getHours(); var minutes_sunset = "0" + date_sunset.getMinutes(); var seconds_sunset = "0" + date_sunset.getSeconds(); var formattedTime_sunset = hours_sunset + 'h' + minutes_sunset.substr(-2); document.getElementById("image-icon").src = 'http://openweathermap.org/img/wn/' + data_parse.weather[0].icon + '@2x.png'; document.getElementById("name").innerHTML = data_parse.name; document.getElementById("temp").innerHTML = temp_value.toFixed(); document.getElementById("humidity").innerHTML = data_parse.main.humidity; document.getElementById("feels_like").innerHTML = feels_like_value.toFixed(); document.getElementById("wind").innerHTML = wind_value.toFixed(); document.getElementById("sunrise").innerHTML = formattedTime_sunrise; document.getElementById("sunset").innerHTML = formattedTime_sunset; document.getElementById("description").innerHTML = data_parse.weather[0].description; } else if (this.readyState == 2 && this.status == 404) { var error_html = `<div class="alert alert-danger alert-dismissible fade in" id="search-error"> <a href="#" class="close" data-dismiss="alert" aria-label="close">&times;</a> <strong>Warning!</strong> Không tìm thấy thông tin thời tiết cho thành phố này </div>`; document.getElementById("weather-info").insertAdjacentHTML('beforebegin', error_html); setTimeout(function() { document.getElementById("search-error").remove(); }, 1500); } searchInput.value = ''; }; }, false);
});

Còn về phần giao diện thì mình để ở file tương ứng là popup.html

Vì mình làm nó đơn giản nên mình chỉ xử lý ở 2 file này thôi ?.

Sau khi xử lý xong, mình để chung thư mục và đóng gói, sau đó bật Chế độ dành cho nhà phát triển của tiện ích trên chrome tại địa chỉ: chrome://extensions/ và mở tới thư mục của extension để hoạt động thôi.

Và kết quả sử dụng thì sẽ như hình bên dưới ?

Cảm ơn các bạn đã đọc bài viết. Chúc các bạn nghỉ lễ vui vẻ ?

Bình luận

Bài viết tương tự

- vừa được xem lúc

Cài đặt WSL / WSL2 trên Windows 10 để code như trên Ubuntu

Sau vài ba năm mình chuyển qua code trên Ubuntu thì thật không thể phủ nhận rằng mình đã yêu em nó. Cá nhân mình sử dụng Ubuntu để code web thì thật là tuyệt vời.

0 0 396

- vừa được xem lúc

Tìm hiểu về cách thiết kế Class Diagram

Trong 1 dự án, việc tổ chức code cũng như clean code là 1 điều rất quan trọng, nếu cách thiết kế các class hợp lý và rõ ràng sẽ giúp ích rất nhiều cho việc mở rộng và bảo trì sau này. Để làm được điều này chúng ta cần phải có 1 bản thiết kế Class Diagram thật sự hợp lý.

0 0 92

- vừa được xem lúc

Vòng đời và trạng thái của Thread

A. Giới thiệu.

0 0 137

- vừa được xem lúc

Sự khác nhau giữa những điều tưởng giống nhau - Phần 3

Hôm nay, để tiếp tục cho series so sánh, hãy cùng mình khám phá thêm 2 địa danh mới khá nổi tiếng của Việt Nam mình đó là Cù Lao Chàm và đảo Lý Sơn. .

0 0 112

- vừa được xem lúc

5 sai lầm phổ biến khi code JavaScript mà bạn ít khi để ý

Bài viết hôm nay mình giới thiệu đến các bạn 5 lỗi lập trình thường gặp trong JavaScript. Tất nhiên mình sẽ không nói về các syntax error, hoặc những lỗi quá bình thường.

0 0 57

- vừa được xem lúc

Cách sử dụng dagger 2 cơ bản trong Android

I. Giới thiệu.

0 0 247