03/08/2018, 10:03

HTML5 localStorage và sessionStorage

Như bạn biết, Cookie trong Javascript có công dụng lưu trữ dữ liệu tạm thời ở browser, chúng ta hay sử dụng nó để lưu trữ các thông tin cấu hình ...

Như bạn biết, Cookie trong Javascript có công dụng lưu trữ dữ liệu tạm thời ở browser, chúng ta hay sử dụng nó để lưu trữ các thông tin cấu hình cho mỗi user và đương nhiên là các thông tin này giữa các users sẽ không liên quan với nhau. Cookie thật sự rất hữu ích và không thể thiếu khi bạn xây dựng website.

Hôm nay mình sẽ giới thiệu với các bạn một loại #HTML API có công dụng tương tự như Cookie, tuy nhiên cách sử dụng đơn giản hơn rất nhiều đó là localStorage

1. HTML5 Local Storage

Local Storage có công dụng tương tự như cookie, có nghĩa là nó sẽ lưu trữ thông tin trên browser mà người dùng đang truy cập. Điểm khác biệt lớn nhất giữa Cookie và Local Storage là Local Storage cho phép bạn lưu trữ thông tin tương đối lớn lên đến 5MB, ngoài ra local storage không gửi thông tin lên server như Cookie. Cả local storage và cookie đều không ảnh hưởng đến hiệu xuất của trang web.

Chúng ta có 2 loại local storage đó là:

  • window.localStorage: Lưu trữ dữ liệu vô thời hạn, dữ liệu sẽ được lưu trữ cho tới khi người dùng clear history.
  • window.sessionStorage: Lưu trữ dữ liệu cho mội phiên làm việc, có nghĩa dữ liệu sẽ bị mất khi bạn tắt browser.

Bây giờ chúng ta sẽ tìm hiểu hai đối tượng này nhé.

2. localStorage Object

localStorage Object lưu trữ dữ liệu vô thời hạn, có nghĩa dữ liệu sẽ không bị mất cho tới khi bạn sử dụng chức năng clear history của trình duyệt, hoặc bạn sử dụng localStorage API để xóa. Chúng ta có hai thao tác chính đó là gán dữ liệu và lấy dữ liệu, và trước khi sử dụng các phương thức này thì ta phải chắc chắn là trình duyệt có hỗ trợ HTML5. Đoạn code dưới đây sẽ giúp ta kiểm tra trình duyệt có hỗ trợ localStorage hay là không.

if (typeof(Storage) !== "undefined") {
    // Có hỗ trợ local storage
} else {
    // Không hỗ trợ local storage
}

So với cookie thì chúng ta không cần làm thao tác này, đây cũng chính là điểm yếu duy nhất của local storage.

Ví dụ: Lưu trữ domain code24h.com vào trình duyệt của người dùng.

Bạn hãy tạo cho mình hai file a.html và b.html với nội dung như sau.

a.html

if (typeof(Storage) !== "undefined") {
    var domain = 'code24h.com';
    localStorage.setItem('domain', domain);
} else {
    document.write('Trình duyệt của bạn không hỗ trợ local storage');
}

b.html

if (typeof(Storage) !== "undefined") {
    var domain = localStorage.getItem('domain');
    document.write(domain); // kết quả code24h.com
} else {
    document.write('Trình duyệt của bạn không hỗ trợ local storage');
}

Bây giờ bạn chạy file a.html trước, sau đó bạn chạy file b.html thì sẽ thấy thông tin domain code24h.com đã dược in lên website, điều này có nghĩa file a.html đã lưu trữ thông tin vào browser rồi nên file b.html mới có thể lấy được thông tin đó. Bây giờ bạn thử tắt trình duyệt và mở lại file b.html để xem dữ liệu còn không nhé.

Như vậy để lưu dữ liệu thì ta dùng phương thức setItem(key, value) và để lấy dữ liệu thì ta dùng phương thức getItem(key).

3. sessionStorage Object

Công dụng của sessionStorage cũng tương tự như localStorage, chỉ có một điểm khác đó là dữ liệu của sessionStorage sẽ mất khi bạn đóng trình duyệt. sessionStorage không tồn tại hai phương thức getItemsetItem mà bạn sẽ bổ sung key và value cho nó.

Ví dụ:

if (typeof(Storage) !== "undefined") {
    // Gán dữ liệu
    sessionStorage.domain = 'code24h.com';
    
    // Lấy dữ liệu
    var domain = sessionStorage.domain; // code24h.com
} else {
    document.write('Trình duyệt của bạn không hỗ trợ local storage');
}

Quay lại ví dụ ở phần 2 thì mình sẽ viết như sau:

a.html

if (typeof(Storage) !== "undefined") {
    sessionStorage.domain = 'code24h.com';
} else {
    document.write('Trình duyệt của bạn không hỗ trợ local storage');
}

b.html

if (typeof(Storage) !== "undefined") {
    document.write(sessionStorage.domain); // kết quả code24h.com
} else {
    document.write('Trình duyệt của bạn không hỗ trợ local storage');
}

4. Lời kết

Trong bài này mình đã giới thiệu xong cách sử dụng hai đối tượng lưu trữ dữ liệu lên trình duyệt của người dùng đó là localStorage và sessionStorage, hai đối tượng này tương đối giống với cookie, chỉ có một số khác biệt như sau:

  • Cookie: Có gửi dữ liệu lên server, có thời gian lưu trữ.
  • localStorage: Không gửi dữ liệu lên server, thời gian lưu trữ vô hạn
  • sessionStorage: Không gửi dữ liệu lên server, dữ liệu bị mất khi đóng trình duyệt.

Rất đơn giản phải không các bạn.

BÀI KẾ SAU
BÀI KẾ TIẾP

Nguồn: code24h.com

0