GithubHelp home page GithubHelp logo

dev's Introduction

I. CHÚ Ý KHI SỬ DỤNG NOTIFICATIONS API

Để sử dụng được Notifications API cần phải chú ý một số điều sau:

  • Người sử dụng cần cấp phép cho trình duyệt hiển thị các thông báo hệ thống, điều này sẽ được thực hiện khi trang web khởi tạo. Các thiết lập này thường được kéo dài trong một phiên làm việc. Để hiển thị thiết lập này cho người dùng lập, trình viên có thể sử dụng requestPermission() method.
  • Để tạo mới một thông báo hệ thống chúng ta sử dụng Notification() constructor, điều này đã bao gồm một số thiết lập như tiêu đề, các đối tượng hiển thị nội dung là văn bản, âm thanh ...
  • Hiện tại Notifications API chỉ support cho một số WebKit browsers như Google Chrome, FireFox và Safari.

II. CÁCH SỬ DỤNG NOTIFICATIONS API

1. Check quyền hiển thị thông báo hệ thống

Để xem người dùng đã cấp quyền cho hiển thị thông báo hệ thống chưa có thể sử dụng method Notification.permission.

Method này sẽ trả về 3 kết quả như sau:

  • Default: Người dùng không trả lời thông báo, nên mặc định sẽ là không cho phép hiển thị thông báo hệ thống.
  • Granted: Người dùng cho phép hiển thị thông báo hệ thống khi được hỏi.
  • Denied: Người dùng từ chối cho phép hiển thị thông báo hệ thống khi được hỏi.

2. Lấy quyền hiển thị thông báo hệ thống từ người dùng

Khi người dùng không chấp nhận cho phép hiển thị thông báo hệ thống lập trình viên có thể hỏi lại người dùng bằng Notification.requestPermission() method.

Notification.requestPermission().then(function(result) { console.log(result); });

Method này sẽ tạo một hộp thoại để hỏi lại người dùng về quyền truy cập hệ thống.

3. Notification events

Notifications API cung cấp một số sự kiện cơ bản cho một thông báo.

  • Click: Sự kiện khi người dùng click vào thông báo.
  • Error: Sự kiện khi việc hiển thị thông báo xảy ra vấn đề lỗi.
  • Close: Sự kiện khi người dùng đóng thông báo.
  • Show: Sự kiện khi thông báo được hiển thị.

4. Notification Properties

Notification API cung cấp một số properties trên Notification Object

  • Notification.title: Tiêu đề của thông báo như được chỉ định trong tham số tùy chọn của hàm tạo.
  • Notification.dir: Hướng văn bản của thông báo như được chỉ định trong tham số tùy chọn của hàm tạo.
  • Notification.lang: Mã ngôn ngữ của thông báo được chỉ định trong tham số tùy chọn của hàm tạo.
  • Notification.body: Chuỗi nội dung của thông báo được chỉ định trong tham số tùy chọn của hàm tạo.
  • Notification.tag: ID của thông báo (nếu có) như được chỉ định trong tham số tùy chọn của hàm tạo.
  • Notification.icon: URL của hình ảnh được sử dụng làm biểu tượng được chỉ định trong thông số tùy chọn của hàm tạo
  • Notification.data: Trả về bản sao có cấu trúc của dữ liệu của thông báo.
  • Notification.requireInteraction: cho biết rằng trên các thiết bị có màn hình đủ lớn, thông báo sẽ vẫn hoạt động cho đến khi người dùng nhấp hoặc loại bỏ nó
  • Notification.silent: Chỉ định xem thông báo có nên im lặng hay không, tức là không phát ra âm thanh hoặc rung, bất kể cài đặt thiết bị.
  • Notification.timestamp: Chỉ định thời gian thông báo được tạo hoặc áp dụng (quá khứ, hiện tại hoặc tương lai).

5. Các trình duyệt hỗ trợ notification API

IE Firefox Chrome Safari Edge iOS Safari Opera Mini Chrome for Android UC Browser for Android
11 61,62,63,64 49,67,68,69,70,71,72 11.1,12,TP 17,18 10.2,10.3,11.2, 11.4, 12 All 69 11.8

dev's People

Contributors

khangnx avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.