原生 PWA 技术分享

面试官:小伙子,你的代码为什么这么丝滑?

PWA 简介

PWA (Progressive Web Apps) 是一种可以让网站更像本地应用程序的技术。 PWA 可以在离线情况下运行,具有更快的加载速度,更好的性能以及与桌面应用程序相似的用户体验。 Google 是 PWA 的主要倡导者,因为它们可以提供更激动人心的互联网体验,同时还可以提高网站的可访问性和可发现性。

原生 PWA 和非原生 PWA

在 PWA 的世界中,有两个术语,即原生 PWA 和非原生 PWA。原生 PWA 意味着使用 Web APIs 功能来增强应用程序。非原生 PWA 意味着在页面 header 中使用一些链接来增加应用程序的功能,例如添加到主屏幕、离线缓存和推送通知。

本篇文章将重点介绍原生 PWA 的技术。

实现原生 PWA 的技术

以下是实现原生 PWA所需的主要技术:

Service Worker

Service Worker 是一个独立的 JavaScript 文件,它可以在 Web 应用程序和网络之间充当代理服务器。它可以缓存 Web 应用程序的文件,以便它们离线访问并跟踪离线数据,例如表单提交和推送通知。

以下是 Service Worker 典型的生命周期:

  1. Service Worker 文件注册
  2. Service Worker 安装
  3. Service Worker 激活
  4. Service Worker 变得可以接收 fetch 事件
  5. Service Worker 卸载

App Manifest

App Manifest 是一个 JSON 文件中的配置,它提供有关 PWA 如何显示和行为的信息。它包括 PWA 的名称,图标和颜色主题。App Manifest 还定义了 PWA 的启动 URL 和起始页,以及屏幕方向和显示模式设置。

Push API

Push API 是一种 Web API,用于向用户设备推送消息。 在 PWA 中,Push API 用于与后台推送通知服务通信以接收推送通知。

PWA 的构建实例

我们将创建一个简单的幻灯片应用程序(Carousel App)作为 PWA 的示例程序,来演示 PWA 的主要特点。

步骤 1 - 创建基本的 HTML 结构

我们将在 index.html 文件中编写我们的 HTML。以下是我们示例的 HTML 结构:

--------- -----
----- ----------
------
    ----- ----------------
    ----- --------------- ---------------------------- ---------------- -----------------
    --------------- -----------
-------
------
    ---- -----------------
        ---- --------------- -------
        ---- --------------- -------
        ---- --------------- -------
    ------
-------
-------

步骤 2 - 引入必要的 CSS

我们需要一些 CSS 样式来构建我们的 Carousel App。

- -
    ------- --
    -------- --
    ----------- -----------
-

--------- -
    -------- -----
    ---------- -------
    ----------- -----
    --------------------------- ------
    ----------------- - ----------
-

--------- --- -
    ------------------ -------
    ------ -----
    ------- -----
    ----------- ------
-

步骤 3 - 实现 PWA 的核心功能

注册 Service Worker

我们需要向 index.html 文件添加以下脚本来注册 Service Worker。

--------
-- -------- ------- ------
-- ---------------- -- ---------- -
    ------------------------------- ---------- -
        ---------------------------------------------------------------------- -
            -------------------- ------ ------------ ------------- --------------
        ------------------------ -
            -------------------- ------ ------------ --------- -------
        ---
    ---
-
---------

缓存 App Shell

我们需要使用 Service Worker 缓存应用程序的 资源 和 文件。我们的应用程序只有一张图片,我们将它们缓存在缓存中。

我们需要创建一个名为 sw.js 的 JavaScript 文件,如下所示:

--- ---------- - ------------------------
--- ----------- - -
    ----
    -------------
    -----------------
    -------------
    ------------
    ------------
    -----------
--

-------------------------------- --------------- -
    -- ------- ------- ----- ------- --- -----
    ----------------
        -----------------------
            --------------------- -
                ------------------- --------
                ------ --------------------------
            --
    --
---

------------------------------ --------------- -
    ------------------
        ---------------------------
            ------------------------ -
                -- ------ ----- ---------- ------ ----
                -- ---------- -
                    ------ ---------
                -
                -- -- ----- -- ------ --- ------- ------- -------
                ------ ---------------------
            --
    --
---

安装应用程序

我们需要使用 Web App Manifest 定义应用程序的元数据,包括名称、图标、背景颜色和主题色。我们在 index.html 文件的头部添加一些元素:

----- -------------- ----------------------
----- ------------------ ------------------
----- ---------------------- ---------------------------------------

其中,href="/manifest.json"引入了我们的 Manifest 文件。Manifest 文件包含以下内容:

-
    ------------- --------- -----
    ------- --------- -----
    ------- --------
    -------- -
        -
            ------ -------------------------------
            ------- ------------
            -------- -------
        --
        -
            ------ -------------------------------
            ------- ------------
            -------- -------
        --
        -
            ------ ---------------------------------
            ------- ------------
            -------- ---------
        --
        -
            ------ ---------------------------------
            ------- ------------
            -------- ---------
        --
        -
            ------ ---------------------------------
            ------- ------------
            -------- ---------
        -
    --
    ------------ --------------
    ---------- ------------
-

步骤 4 - 集成 Push API

我们需要向 Service Worker 添加接受 Push 通知的功能。我们需要在 sw.js 文件中添加以下代码:

----------------------------- --------------- -
    ----------------- ------------ ----------- -------
    --- ----- - --------- -----
    --- ------- - -
        ----- ---------- - ----------------- - --------- --- --------------
        ----- ----------------------------------
        ------ --------------------------------
        ----- -
            ---- -----------------------------------
        -
    --

    ----------------
        ----------------------------------------- --------
    --
---

结论

通过 Service Worker、App Manifest 和 Push API,我们可以创建优秀的 PWA。本文已经为你介绍了如何创建一个简单的 Carousel App,并演示了 PWA 的核心技术、模式和结构。能够使用 PWA 技术开发更好的 Web 应用程序,将会是未来 Web 开发的重要方向,我们鼓励开发者继续深入了解 PWA 的技术与应用场景。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/66efc2d26fbf96019730c27d


猜你喜欢

  • 从 ES12 的 Weak Refs 看 JavaScript 中的原始类型存储

    ES12 引入了一项新特性,称为 Weak Refs。这项特性提供了一种弱引用的方式,可用于存储 JavaScript 中的原始类型,例如数字和字符串。 在本文中,我们将深入探讨 Weak Refs ...

    25 天前
  • ES10 关于数组方法 map() 的讲解

    在前端开发中,我们经常需要对数组进行操作和处理。ES10中的数组方法map()就是一种非常常用的方法。本篇文章将为读者详细介绍map()方法的用法和使用注意事项,帮助读者更好地理解和使用这个方法。

    25 天前
  • 解决使用 Tailwind 框架时样式不一致的问题

    如果你正在使用 Tailwind CSS 框架来构建前端网站或应用程序,你可能会遇到一些让人烦恼的问题。其中之一是样式不一致,尤其是在多个页面或组件之间。 在这篇文章中,我们将探讨一些常见的原因和解决...

    25 天前
  • 使用 Socket.IO 实现在线游戏平台的指南

    随着互联网的飞速发展,网络游戏已成为当今最为热门的产品之一。作为前端工程师,我们经常需要使用不同的技术来开发和实现各种在线游戏平台。其中,Socket.IO 是一个强大的工具,可以帮助我们实现实时通信...

    25 天前
  • Flexbox 布局详解

    Flexbox 属于 CSS3 的一部分,它提供了一种在容器内部方便地对项目进行布局的方式,以及在不同屏幕尺寸下的响应式设计,更为重要的是灵活性极高,它是 Web 布局的未来。

    25 天前
  • Redis 应用场景探究 —— 分布式锁的应用

    前言 Redis 是当今非常流行的一种内存中数据存储系统,广泛应用于Web应用领域。除了一些基本的数据类型以外,Redis 还提供了许多实用的功能,如发布/订阅,事务,以及不少人所熟知的应用场景 ——...

    25 天前
  • TypeScript 中的抽象类

    抽象类是 TypeScript 中的高级特性,它提供了一种模板方法模式的实现方式,可以使得代码更加的简洁和可维护。在本文中,我们将深入探讨 TypeScript 中的抽象类。

    25 天前
  • 从 Babel7 到 Babel8,我们该如何升级?

    Babel 是一个非常流行的 JavaScript 编译器,它可以将 ES2015+ 的代码转换成向后兼容的 JavaScript 代码。Babel 8 是 Babel 的最新版本,它带来了许多新的功...

    25 天前
  • 在 Deno 中使用 Serverless

    介绍 Serverless 是一种全新的云计算方式,它能够帮助前端开发者快速搭建后端服务,以此来支持前端应用程序的开发和部署。从细节角度来看, Serverless 实现了一种无服务器架构,这代表着代...

    25 天前
  • 处理无障碍 JavaGUI 应用程序中的扫描事件

    在日常生活中,有一些人群需要使用无障碍功能来轻松地访问电子设备,包括电脑。对于 JavaGUI 应用程序来说,我们也可以通过处理扫描事件来实现无障碍功能,让这些用户更加轻松地使用我们的应用程序。

    25 天前
  • Material Design 中的工具提示组件使用指南

    工具提示是常见的用户界面设计元素,用于提供关于某个元素或功能的额外信息和指导。Material Design 中的工具提示组件可以轻松地添加此类元素,并以一致的方式呈现。

    25 天前
  • 在 React 应用中使用 Server-Sent Events

    随着 Web 应用程序需求的增长,需要实时数据推送的应用程序也越来越普遍。传统的轮询和 WebSocket 等协议的实现需要复杂的设置和处理,而 Server-Sent Events (SSE) 提供...

    25 天前
  • ES12 中的 for-await-of 循环详解

    在 ES12 中,引入了 for-await-of 循环,以便更方便地处理异步迭代器。本文将详细介绍 for-await-of 循环的使用和特性。 异步迭代器和 Iterable/Iterator 在...

    25 天前
  • ES10 的 Promise.all() 和 Promise.race()

    在前端开发中,异步操作是一个不可避免的问题。为了更好地处理异步操作,JavaScript提供了Promise,它能够处理异步请求,我们可以通过then链式地进行处理。

    25 天前
  • 如何优化 Lambda 函数运行性能

    在服务器端架构中,AWS Lambda 是一个非常有用的服务。它可以管理应用程序的服务器资源,帮助开发者将重心放在应用程序的业务逻辑和后端服务之上。如果你使用 AWS Lambda 来运行你的应用程序...

    25 天前
  • 如何在 Karma 单元测试中使用 Chai 和 Mocha

    如何在 Karma 单元测试中使用 Chai 和 Mocha 在前端开发中,单元测试是非常重要的,它可以确保代码的质量和稳定性。Karma 是一个流行的 JavaScript 测试运行器,而 Chai...

    25 天前
  • RESTful API 中使用 Swagger 的好处

    Swagger 是一个流行的 API 开发工具,它提供了一种方便的方式来设计、编写和测试 RESTful API。在本文中,我们将探讨 RESTful API 中使用 Swagger 带来的好处、如何...

    25 天前
  • MongoDB 的聚合查询实现和应用场景

    前言 MongoDB 是一种非关系型数据库,对于前端开发来说,它具有很好的适用性。在实际应用中,我们通常需要从数据库中获取数据,而聚合查询则是一种非常常用的获取数据的方式。

    25 天前
  • C++ 容器类性能优化探究

    介绍 C++ 是一门强大的编程语言,拥有多个不同的容器类型,比如数组、向量、列表、映射等等。在使用容器时,我们要尽可能地优化它们的性能,以确保程序的高效运行并减少资源消耗。

    25 天前
  • RxJS 的 mat 冻结 bug 及其解决方案

    背景 在前端开发中,RxJS 的应用越来越广泛,并且在一些大型项目中,RxJS 已成为主要的状态管理工具。在使用 RxJS 过程中,有时会遇到 mat 冻结的问题。

    25 天前

相关推荐

    暂无文章