首页 >web前端 >js教程 >渐进式 Web 应用程序:Web 开发的未来

渐进式 Web 应用程序:Web 开发的未来

PHPz
PHPz原创
2024-09-05 06:48:07742浏览

Progressive Web apps: O futuro do desenvolvimento web

关于 PWA 的热门话题是什么?

想象一下:您在地铁上,尝试用手机访问网站,但互联网信号不断下降。令人沮丧,对吧?
这就是渐进式 Web 应用程序的用武之地,它是网络世界的超级英雄。它可以离线工作,以闪电般的速度加载,甚至可以发送通知。这就像赋予您的网站超能力!

PWA 的起源

让我们回到过去(比如 2015 年),选项是:构建一个网站或构建一个应用程序。这就像在自行车或汽车之间进行选择一样。然后谷歌的一些聪明人想,“为什么不两者都做呢?”于是,PWA 诞生了!

让我们构建我们的第一个 PWA:开始冒险

让我们卷起袖子,一起构建一个简单的 PWA。
让我们创建一个“糟糕的笑话”应用程序,因为谁不喜欢糟糕的笑话呢?

第 1 部分:基础知识 - 只是一个简单的网页

首先,让我们创建一些基本的 HTML。这是我们的“自行车” - 它可以工作,但还不是超级强大。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Dad Jokes PWA</title>
    <link rel="stylesheet" href="style.css">
</head>
<body>
    <h1>Dad Jokes</h1>
    <p id="joke">Click the button for a dad joke!</p>
    <button id="jokeBtn">Get New Joke</button>
    <script src="app.js"></script>
</body>
</html>

第 2 部分:添加一些样式 - 因为每个糟糕的笑话都需要好看。

让我们添加一点 CSS 以使我们的应用程序更加优雅:

body {
    font-family: Arial, sans-serif;
    text-align: center;
    padding: 20px;
}

#joke {
    margin: 20px 0;
    font-style: italic;
}

button {
    padding: 10px 20px;
    font-size: 16px;
    cursor: pointer;
}

第 3 部分:javascript 的魔力 = 请求糟糕的笑话

现在,让我们添加一些 JavaScript 来向将返回笑话的 API 发出请求:

const jokeElement = document.getElementById('joke');
const jokeBtn = document.getElementById('jokeBtn');

async function fetchJoke() {
    try {
        const response = await fetch('https://icanhazdadjoke.com/', {
            headers: {
                'Accept': 'application/json'
            }
        });
        const data = await response.json();
        jokeElement.textContent = data.joke;
    } catch (error) {
        jokeElement.textContent = "Oops! Looks like the joke got stuck in dad's old briefcase.";
    }
}

jokeBtn.addEventListener('click', fetchJoke);

// Faz o request na API quando a página carrega
fetchJoke();

第 4 步:转变为 PWA - 一点超能力

现在,让我们将普通网站改造成 PWA。首先,我们需要一个清单文件。创建一个名为manifest.json的文件:

{
    "name": "Dad Jokes PWA",
    "short_name": "DadJokes",
    "start_url": "/",
    "display": "standalone",
    "background_color": "#ffffff",
    "theme_color": "#4285f4",
    "icons": [
        {
            "src": "icon.png",
            "sizes": "192x192",
            "type": "image/png"
        }
    ]
}

不要忘记在 HTML 文件中添加清单链接

<link rel="manifest" href="manifest.json">

第五步:秘密武器:Service Workers

Service Workers 就像网络上隐形的小管家。他们缓存您的资产,甚至可以离线工作。创建一个名为 service-worker.js 的文件:

const CACHE_NAME = 'dad-jokes-cache-v1';
const urlsToCache = [
    '/',
    '/index.html',
    '/style.css',
    '/app.js',
    '/icon.png'
];

self.addEventListener('install', event => {
    event.waitUntil(
        caches.open(CACHE_NAME)
            .then(cache => cache.addAll(urlsToCache))
    );
});

self.addEventListener('fetch', event => {
    event.respondWith(
        caches.match(event.request)
            .then(response => response || fetch(event.request))
    );
});

现在,在您的 app.js 文件中注册 Service Worker

if ('serviceWorker' in navigator) {
    window.addEventListener('load', () => {
        navigator.serviceWorker.register('/service-worker.js')
            .then(registration => console.log('ServiceWorker registered'))
            .catch(error => console.log('ServiceWorker registration failed:', error));
    });
}

测试 PWA 超能力

  • 离线模式:关闭互联网并刷新页面。您的应用程序应该仍然可以运行!
  • 安装提示:在支持的浏览器中,您将看到安装 PWA 的选项。
  • Lighthouse Audit:使用 Chrome 的 Lighthouse 工具来检查你的 PWA 的超能力。

未来是进步的

恭喜!您刚刚构建了第一个 PWA。这就像看着您的孩子迈出第一步,不是吗? (说到糟糕的笑话...)

随着我们迈向 2024 年,PWA 变得越来越强大。他们可以访问设备功能、离线工作并提供类似应用程序的体验,而无需使用应用程序商店。

因此,下次有人问您是否可以创建网站或应用程序时,您可以说:“为什么不能两者都做呢?”并向他们介绍 PWA 的奇妙世界!

制作人员

渐进式 Web 应用程序:Web 开发的未来,最初由 Baransel 编写

感谢您阅读这篇文章。我希望能为您提供一些有用的信息。如果是这样,如果您推荐这篇文章并点击 ♥ 按钮,以便更多人可以看到这篇文章,我将非常高兴。

以上是渐进式 Web 应用程序:Web 开发的未来的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn