, October 26, 2021

0 kết quả được tìm thấy

Tìm hiểu thêm về Window Object trong Javascript


  •   6 min reads
Tìm hiểu thêm về Window Object trong Javascript

Nếu các bạn đã xem các bài trước thuộc series JavasScript cơ bản của mình hoặc đã xem các tài liệu khác thì chắc hẵn đã từng thấy trong bài viết có đề cập đến ông thần window object rồi nhỉ 😉. Vậy trong bài này, chúng ta sẽ cùng nhau tìm hiểu về nó để xem window object là loại object như thế nào nhé 😁.

I. BOM là cái gì?

BOM? Có vẻ như từ này khá lạ với các bạn phải không 😁, thực chất từ này là viết tắt của cụm từ Browser Object Model - nghĩa là các object liên quan đến trình duyệt mà thôi.

Mỗi trình duyệt khác nhau sẽ có các object hơi khác một chút, do đó giữa các BOM với nhau sẽ không có một chuẩn chung nào cả. Có thể bạn chưa biết, DOM và các thông báo dạng popup ở ngoài màn hình cũng nằm trong BOM group đấy 😉.

II. Window object là object gì?

Rồi! Giờ đến ông thần window object này. Như tên gọi của nó, nó là object có tác động đến cửa sổ trình duyệt của chúng ta và nó cũng được tích hợp lên hầu hết các trình duyệt ngày nay.

Cùng xem thử ta có thể dùng nó để tác động lên cửa sổ trình duyệt của chúng ta như thế nào nhé 😁.

1. Lấy thông số của cửa sổ trình duyệt.

Như mình đã nói ở trên, thì mỗi trình duyệt sẽ có BOM hơi khác nhau một chút dó đó cách lấy thông tin ra cũng hơi khác tý.

//Lấy chiều dài của của sổ trình duyệt
window.innerWidth;
document.documentElement.clientWidth;
document.body.clientWidth;

//Lấy chiều cao của của sổ trình duyệt
window.innerHeight;
document.documentElement.clientHeight;
document.body.clientHeight;

Đối với trình duyệt chrome thì cả 3 các lấy thông tin cửa sổ đều chạy tốt nha 😁

Lưu ý:

2. Mở một của sổ trình duyệt mới.

Để mở một cửa sổ trình duyệt mới, ta dùng hàm open() với cú pháp như sau:

window.open(url, name, specs, replace);

Chú thích:

  • url: là địa chỉ mà chúng ta muốn mở.
  • name: là tên bạn muốn đặt cho cửa sổ đó.
  • specs: Đây là các thông số cho cửa sổ như:

 - Chiều cao của trình duyệt: height (đơn vị pixel).

 - Chiều rộng của trình duyệt: width (đơn vị pixel).

 - Vị trí hiển thị của của sổ trình duyệt: top (đơn vị pixel), left (đơn vị pixel).

 - Hiển thị thanh menu: yes|1 hoặc no|0.

 - Hiển thị thanh trạng thái: yes|1 hoặc no|0.

  • replace: [Có thể có hoặc không] là chỉ định xem URL có tạo ra mục nhập mới hay thay thế mục hiện tại trong danh sách lịch sử không(true hoặc false).
window.open('https://200lab.io/', '200lab Education - Học viện đào tạo kỹ sư Golang và Flutter', 'width=500,height=600');

Kết quả:

3. Đóng một cửa sổ trình duyệt bất kỳ.

Để đóng một cửa sổ trình duyệt bất kỳ ta dùng hàm close() của window object và kèm theo đó là đối tượng cửa sổ mà ta muốn đóng.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Demo window</title>
</head>
<body>
    <div>Click vào button để xem kết quả</div>
	<button type="button" onclick="openNewWindow()">Mở cửa sổ</button>
	<button type="button" onclick="closeWindow()">Đóng cửa sổ</button>
    <script>
        let newWindow = null;

        function openNewWindow() {
            newWindow = window.open('https://200lab.io/', '200lab Education - Học viện đào tạo kỹ sư Golang và Flutter', 'width=500,height=600');
        }

        function closeWindow() {
	        newWindow.close();
        }
    </script>    
</body>
</html>

Các bạn tự chạy thử nha 😁.

4. Di chuyển của sổ trình duyệt trên màn hình.

Ta có thể điều chỉnh vị trí cho cửa sổ trình duyệt xuất hiện ở mọi vị trí trên màn hình của mình. Điều đầu tiên là ta phải biết cửa sổ trình duyệt mà ta muốn di chuyển sau đó dùng hàm moveTo() để thực hiện. Cú pháp của nó như sau:

winObject.moveTo(top,left)

Chú thích: winObject là đối tượng cửa sổ trình duyệt mà bạn muốn thực hiện.

Ví dụ:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Demo window</title>
</head>
<body>
    <div>Click vào button để xem kết quả</div>
	<button type="button" onclick="openNewWindow()">Mở cửa sổ</button>
	<button type="button" onclick="moveWindow()">Di chuyển cửa sổ</button>
    <script>
        let newWindow = null;

        function openNewWindow() {
            newWindow = window.open('https://200lab.io/', '200lab Education - Học viện đào tạo kỹ sư Golang và Flutter', 'width=300,height=200');
        }

        function moveWindow() {
	        newWindow.moveTo(200, 400);
            newWindow.focus();
        }
    </script>    
</body>
</html>

5. Thay đổi kích thước của cửa sổ trình duyệt.

Để thay đổi kích thước cửa sổ trình duyệt ta cầ n xác định được đối tượng cửa sổ trình duyệt mà ta muốn thay đổi và kết hợp với hàm resizeTo().

winObject.resizeTo(width,height);

Chú thích: winObject là đối tượng cửa sổ trình duyệt mà bạn muốn thực hiện.

Ví dụ:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Demo window</title>
</head>
<body>
    <div>Click vào button để xem kết quả</div>
	<button type="button" onclick="openNewWindow()">Mở cửa sổ</button>
	<button type="button" onclick="resizeWindow()">Thay đổi kích thước cửa sổ</button>
    <script>
        let newWindow = null;

        function openNewWindow() {
            newWindow = window.open('https://200lab.io/', '200lab Education - Học viện đào tạo kỹ sư Golang và Flutter', 'width=300,height=200');
        }

        function resizeWindow() {
	        newWindow.resizeTo(500, 700);
            newWindow.focus();
        }
    </script>    
</body>
</html>

II. Tổng kết.

Trên đây là giới thiệu sơ lượt về khái niệm BOM là gì? window object là gì? kèm theo là một vài ví dụ về các window object properties đơn giản ngoài ra nó còn nhiều lắm nhé 😁. Nếu có nhu cầu biết thêm về tất cả các properties của ông thần này thì bạn có thể tìm đọc tại đây nhé 😉.

Cảm ơn các bạn đã đọc 🤗

Bài viết cùng seri

Bài viết liên quan

Hướng dẫn clone instagram với React JS và Firebase phần 2.

Trong phần 1 của series này, chúng ta tiến hành setup một project ReactJS bằng câu lệnh create-react-app,đăng ký và tạo app trên firebase để có thể sử dụng và lưu trữ data. Trong phần 2 này, chúng ta sẽ tạo header cho nó và tạo component post để hiển thị bài đăng nhé 😉. Nào bắt đầu thôi 😁!...

Hướng dẫn clone instagram với React JS và Firebase phần 2.
Hướng dẫn clone instagram với React JS và Firebase phần 1.

Trong bài viết này, chúng ta sẽ cùng nhau clone một trang mạng xã hội nỗi tiếng, là nơi chia sẽ hình ảnh và video của hàng trăm triệu người trên toàn thế giới, đó chính là Instagram. Chúng ta bắt đầu thôi 😁!...

Hướng dẫn clone instagram với React JS và Firebase phần 1.
Number, string, array và object trong JavaScript

Chúng ta đã cùng nhau tìm hiểu các kiểu dữ liệu có trong JavaScript ở bài trước, tuy nhiên chúng ta vẫn chưa biết cách thao tác với chúng như thế nào trong JavaScript, nó có hổ trợ các phương thức nào hay không? Vấn đề đó, chúng ta sẽ cùng nhau tìm hiểu trong bài này nhé 😉....

Number, string, array và object trong JavaScript
Tìm hiểu về "this" trong JavaScript.

Chắc hẵn bạn đã từng nhìn thấy từ this trong một ngôn ngữ lập trình nào trước đó hoặc là trong một vài đoạn code nào đó của JavaScript. Bạn thắc mắc nó có tác dụng gì hoặc là bạn đang mơ hồ về this trong JavaScript. Yên tâm, trong bài này chúng ta sẽ cùng nhau tìm hiểu this có ý nghĩa gì nhé....

Tìm hiểu về "this" trong JavaScript.
Có gì mới ở ES2022?

ES2021/ES12 mới vừa ra mắt hồi giữa năm còn nóng hổi thì giờ đây ES2022/ES13 đã được ra mắt, thật quá nhanh quá nguy hiểm đi mà 😆. Công nghệ cập nhật và thay đổi không ngừng với tốc độ thật đáng kinh ngạc. Không chần chừ thêm nữa ta cùng nhau tìm hiểu xem ở ES2022 có gì đặc sắc nào 😋...

Có gì mới ở ES2022?
You've successfully subscribed to 200Lab Blog
Great! Next, complete checkout for full access to 200Lab Blog
Xin chào mừng bạn đã quay trở lại
OK! Tài khoản của bạn đã kích hoạt thành công.
Success! Your billing info is updated.
Billing info update failed.
Your link has expired.