目录
>您必须熟悉常规通知。这些是屏幕上出现在
),因此,如果您还没有,请务必创建一个。现在,转到Atlas仪表板侧边栏中的“数据库访问”选项卡。通过单击右侧的绿色按钮来添加新的数据库用户。输入用户的详细信息(不要忘记密码),然后创建用户。
>现在,这将允许我们在API目录中使用“需要语句”。使用此命令安装MongoDB连接驱动程序:
接下来,让MongoDB客户端这样:
>现在,让我们为跟踪器的实际跟踪功能添加功能。如果您打开Tracker.Svelte,您会注意到有两个功能 - track()和untrack()。这些函数应分别通过将其添加到数据库中来跟踪和解开存储库。
未跟踪存储库
>列表跟踪的存储库
上支持。是的,您可以使用支持的浏览器
>在我们发送推送通知之前,我们需要获得用户的许可。您可以使用notification.requestpermission()方法进行此操作。此方法是
请记住将CD到API文件夹,否则Web-Push软件包将安装在Svelte App中。
步骤6:创建一个cron作业
什么是svelte,为什么我应该使用它来创建github跟踪器?
>我如何自定义Sevelte通知的外观?可以使用CSS自定义Svelte中的通知。 Svelte允许您编写仅适用于定义的组件的范围CSS。这意味着您可以在不影响其余应用程序的情况下为您的推送通知创建独特的样式。
>在Svelte中创建GITHUB跟踪器时,如何处理错误?
我可以使用SVELTE创建私人存储库的GitHub Tracker吗? >
如何在Svelte或GitHub API更改时如何更新我的GitHub Tracker?当Svelte或GitHub API更改时,您需要相应地更新GitHub跟踪器。这可能涉及更新您的Svelte代码以使用新功能或语法,或更新API调用以匹配GitHub API中的更改。重要的是要定期检查更新,以确保您的github跟踪器继续正常工作。
首页 web前端 js教程 在Svelte中创建带有推送通知的GitHub跟踪器

在Svelte中创建带有推送通知的GitHub跟踪器

Feb 09, 2025 am 10:11 AM

在Svelte中创建带有推送通知的GitHub跟踪器

>在本文中,您将学习如何构建一个GitHub跟踪器,该跟踪器通过发送推送通知在跟踪存储库上有新的问题/PR时通知用户。

如果您选择使用,

添加服务工作者并将跟踪器转换为PWA
    >
  • 订阅推送通知
  • 使用github api
  • >通过Vercel Cloud功能发送推送事件
  • 使用EasyCron
  • 定期提取新问题
  • >先决条件

您需要遵循本文的一些技能和服务:>

> node.js和npm已安装

    先前的Svelte知识
  • 一个免费的github帐户,因为我们正在使用github api
  • >免费的mongodb atlas帐户在云中使用mongodb
  • >一个免费的vercel帐户,用于部署应用程序和云功能
  • >
  • 推动通知是什么?
  • >
  • >让我们看看这些所谓的“推送通知”是什么。
>

>您必须熟悉常规通知。这些是屏幕上出现在

上的文字的小气泡。推送通知是相似的,除了它们不是按点播

生成的,但是在接收推动事件

>时会生成它们。当应用程序关闭

时,推送通知工作,而常规通知要求您打开应用程序。> 通过使用所谓的服务工人,在现代网络浏览器(例如Chrome)中支持推送通知。服务工作人员是与浏览器主线程分开运行的JavaScript的小部分,因此,如果将您的应用程序安装为PWA(Progressive Web应用程序)。 >推送通知在聊天应用程序中使用以通知用户在游戏中未读消息时通知他们,以通知用户,在新闻网站中通知用户,以通知用户,以通知用户,并出于许多其他目的。 有四个步骤可以在您的应用中显示推送通知: > window.notification.requestpermission()>请求许可

>将您的应用程序转换为PWA并安装

订阅推送事件

>

收到推送事件后,发送通知

    >步骤1:创建跟踪器
  1. 在本文中,让我们将Svelte与Vite.js一起使用,而不是滚动。顾名思义,Vite IS比汇总更快,并且还为环境变量提供内置支持。要使用Svelte和Vite创建一个新项目,请运行以下命令:
  2. 选择要苗条的框架。如果需要,可以使用打字稿。我将使用常规的JavaScript。
  3. 接下来,CD到项目文件夹中,您可以在应用程序中添加parwindcss,并使用这些命令安装所有依赖项:

    <span>npm init vite
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    最后,在您喜欢的代码编辑器中打开项目,然后运行NPM运行DEV或YARN DEV,以在http:// localhost:3000。

    跟踪器将如何工作

    >我们将使用GitHub API获取问题列表,并提取用户跟踪的存储库的请求。用户的跟踪存储库及其用户名将存储在MongoDB数据库中。

    >第一步是提示用户获取用户名。创建src/lib/usernameprompt.svelte,这将是这样做的组件。这是我的UI,但您可以根据需要进行设计:

    >在app.svelte中添加此组件。
    npx svelte-add tailwindcss
    
    <span># Install packages
    </span><span>yarn install # or npm install
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    接下来,让我们添加主跟踪器UI。创建文件src/lib/tracker.svelte并在其中添加以下代码:>

    测试您的组件,
    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>let username = "";
    </span></span></span><span><span>  <span>async function submit() {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><form</span>
    </span></span><span>  <span><span>on:submit|preventDefault</span><span>="{submit}"</span>
    </span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
    </span></span><span><span>></span>
    </span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>Enter a username<span><span></h1</span>></span>
    </span>  <span><span><span><p</span> class<span>="text-center text-xl m-4"</span>></span>Enter a username to use this tracker<span><span></p</span>></span>
    </span>
      <span><span><span><input</span>
    </span></span><span>    <span>type<span>="text"</span>
    </span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
    </span></span><span>    <span>placeholder<span>="Username"</span>
    </span></span><span>    <span>aria-label<span>="Username"</span>
    </span></span><span>    <span><span>bind:value</span><span>="{username}"</span>
    </span></span><span>  <span>/></span>
    </span>
      <span><span><span><button</span>
    </span></span><span>    <span>class<span>="mt-4 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
    </span></span><span>  <span>></span>
    </span>    Submit
      <span><span><span></button</span>></span>
    </span><span><span><span></form</span>></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    暂时

    将用户名组件换成app.svelte中的新跟踪器组件:
    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>import <span>UsernamePrompt</span> from "./lib/UsernamePrompt.svelte";
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><UsernamePrompt</span> /></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    您的屏幕现在应该看起来像这样:

    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>let repo = "";
    </span></span></span><span><span>  <span>function track() {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span>
    </span></span><span><span>  <span>function untrack(repo) {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><form</span>
    </span></span><span>  <span><span>on:submit|preventDefault</span><span>={track}</span>
    </span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
    </span></span><span><span>></span>
    </span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>GitHub tracker<span><span></h1</span>></span>
    </span>
      <span><span><span><input</span>
    </span></span><span>    <span>type<span>="text"</span>
    </span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
    </span></span><span>    <span>placeholder<span>="Enter the repository's URL"</span>
    </span></span><span>    <span>aria-label<span>="Repository URL"</span>
    </span></span><span>    <span><span>bind:value</span><span>={repo}</span>
    </span></span><span>  <span>/></span>
    </span>  <span><span><span><button</span>
    </span></span><span>    <span>class<span>="mt-2 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
    </span></span><span>    <span>></span>Track repository<span><span></button</span>
    </span></span><span>  <span>></span>
    </span>
      <span><span><span><h2</span> class<span>="mt-4 text-2xl"</span>></span>Tracked repositories<span><span></h2</span>></span>
    </span>  <span><span><span><ul</span> class<span>="m-2 list-decimal"</span>></span>
    </span>    <span><!-- We'll use a loop to automatically add repositories here later on. -->
    </span>    <span><span><span><li</span> class<span>="py-1 flex items-center justify-between"</span>></span>
    </span>      <span><span><span><a</span> class<span>="text-gray-500 hover:underline"</span> href<span>="https://github.com/test/test"</span>
    </span></span><span>        <span>></span>https://github.com/test/test<span><span></a</span>
    </span></span><span>      <span>></span>
    </span>      <button  on:click={() => untrack("")}
            >Untrack<span><span><span></button</span>
    </span></span><span>      <span>></span>
    </span>    <span><span><span></li</span>></span>
    </span>  <span><span><span></ul</span>></span>
    </span><span><span><span></form</span>></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    >

    注意:请记住将App.svelte还原到其先前的代码!

    步骤2:设置云功能在Svelte中创建带有推送通知的GitHub跟踪器

    >我们需要有一个后端服务器将推动事件发送到我们的应用程序。这意味着您需要创建一个新的(也许)ExpressJS项目,然后单独部署。对于仅尝试使用推送通知的人来说,这都是头痛。

    > Vercel Cloud功能可以进行救援!云功能就像快速路由。他们可以运行代码并在获取其URL时给您响应。 Vercel支持云功能;您只需要在API文件夹中创建文件即可。您将使用云功能与MongoDB进行交互,因为公开秘密客户端绝不是一件好事。> 首先,请确保您在MongoDB地图集中有一个集群。 MongoDB有一个免费的计划(

    M0

    ),因此,如果您还没有,请务必创建一个。现在,转到Atlas仪表板侧边栏中的“数据库访问”选项卡。通过单击右侧的绿色按钮来添加新的数据库用户。输入用户的详细信息(不要忘记密码),然后创建用户。

    >

    要连接到数据库,您需要连接字符串。将新用户和密码保存在某个地方,然后转到群集的概述。单击右侧的连接按钮,然后选择“连接应用程序”作为连接方法。您应该看到一个类似于下面的连接字符串。

    >

    >现在您拥有连接字符串,可以连接到数据库,但是首先,您需要将当前应用程序部署到Vercel。最简单的方法是使用github。

    >创建一个新的github存储库,然后将代码推向它。接下来,前往您的Vercel仪表板,然后单击“新项目”按钮。导入您的github存储库,确保框架是vite的,并添加一个称为mongodb_url的环境变量。将其值设置为MongoDB数据库的连接字符串。

    >部署了网站后,您需要将本地开发命令从Yarn Dev更改为Vercel Dev。运行命令后,如果您要求您链接到现有项目,请单击“是”。

    >

    注意:如果还没有,请确保使用NPM I -G Vercel安装Vercel CLI。 像我一样,如果您遇到了与Vercel Dev一起使用Vite的问题,请确保将项目的开发命令更改为Vite -Port $ port从Vercel dashboard中的Vite中。

    这将使我们能够在本地使用正确的环境变量使用云功能。> >让我们添加一个助手文件,该文件将使我们能够访问MongoDB而不会打开太多连接。创建文件api/_mongo.js,然后将以下代码放入其中。 API目录中的一个文件,该文件以_ will 为前缀的文件被视为云功能。这使我们能够在单独的文件中添加助手和其他逻辑:

    >导出连接承诺而不是主要客户端本身将阻止我们在无服务器平台上工作。

    使用commonjs代替eSmodules 请注意我如何使用需要而不是导入?这是因为,从撰写本文开始,Vercel Cloud Functions

    不支持JavaScript文件中的Esmodule导入语句。相反,您需要使用commonjs需要语句。
    <span>npm init vite
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    >这里有一个问题。如果您看到了我们应用程序的包装。这意味着项目中的每个JavaScript文件都是Esmodule。这不是我们想要的,因此要将API目录中的所有文件标记为commonjs文件,因此我们可以使用require语句,创建api/package.json。

    >现在,这将允许我们在API目录中使用“需要语句”。使用此命令安装MongoDB连接驱动程序:

    步骤3:添加功能 到目前为止,跟踪器

    并没有真正起作用,所以让我们解决这个问题。>

    身份验证

    npx svelte-add tailwindcss
    
    <span># Install packages
    </span><span>yarn install # or npm install
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    >用于身份验证,我们需要存储用户在MongoDB数据库中输入的用户名。

    >创建一个file /api /storeusername.js。这将是一个云功能,并将映射到http:// localhost:3000/api/storeusername。将以下代码放在其中:

    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>let username = "";
    </span></span></span><span><span>  <span>async function submit() {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><form</span>
    </span></span><span>  <span><span>on:submit|preventDefault</span><span>="{submit}"</span>
    </span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
    </span></span><span><span>></span>
    </span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>Enter a username<span><span></h1</span>></span>
    </span>  <span><span><span><p</span> class<span>="text-center text-xl m-4"</span>></span>Enter a username to use this tracker<span><span></p</span>></span>
    </span>
      <span><span><span><input</span>
    </span></span><span>    <span>type<span>="text"</span>
    </span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
    </span></span><span>    <span>placeholder<span>="Username"</span>
    </span></span><span>    <span>aria-label<span>="Username"</span>
    </span></span><span>    <span><span>bind:value</span><span>="{username}"</span>
    </span></span><span>  <span>/></span>
    </span>
      <span><span><span><button</span>
    </span></span><span>    <span>class<span>="mt-4 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
    </span></span><span>  <span>></span>
    </span>    Submit
      <span><span><span></button</span>></span>
    </span><span><span><span></form</span>></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    接下来,让MongoDB客户端这样:

    <span>npm init vite
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    从请求的正文中提取用户名:

    npx svelte-add tailwindcss
    
    <span># Install packages
    </span><span>yarn install # or npm install
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    接下来,您需要将此用户名存储在数据库中:>

    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>let username = "";
    </span></span></span><span><span>  <span>async function submit() {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><form</span>
    </span></span><span>  <span><span>on:submit|preventDefault</span><span>="{submit}"</span>
    </span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
    </span></span><span><span>></span>
    </span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>Enter a username<span><span></h1</span>></span>
    </span>  <span><span><span><p</span> class<span>="text-center text-xl m-4"</span>></span>Enter a username to use this tracker<span><span></p</span>></span>
    </span>
      <span><span><span><input</span>
    </span></span><span>    <span>type<span>="text"</span>
    </span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
    </span></span><span>    <span>placeholder<span>="Username"</span>
    </span></span><span>    <span>aria-label<span>="Username"</span>
    </span></span><span>    <span><span>bind:value</span><span>="{username}"</span>
    </span></span><span>  <span>/></span>
    </span>
      <span><span><span><button</span>
    </span></span><span>    <span>class<span>="mt-4 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
    </span></span><span>  <span>></span>
    </span>    Submit
      <span><span><span></button</span>></span>
    </span><span><span><span></form</span>></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    >最后,这就是API/storeusername.js文件应看起来:>

    >将您的应用程序通过Vercel。将您的应用程序部署到Vercel。或推送到GitHub,您的无服务器功能应该是实时的!您可以使用此命令使用卷曲来对其进行测试:
    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>import <span>UsernamePrompt</span> from "./lib/UsernamePrompt.svelte";
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><UsernamePrompt</span> /></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    这应该在用户集合中创建一个新文档,其中_id字段是我们刚刚给出的用户名。
    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>let repo = "";
    </span></span></span><span><span>  <span>function track() {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span>
    </span></span><span><span>  <span>function untrack(repo) {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><form</span>
    </span></span><span>  <span><span>on:submit|preventDefault</span><span>={track}</span>
    </span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
    </span></span><span><span>></span>
    </span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>GitHub tracker<span><span></h1</span>></span>
    </span>
      <span><span><span><input</span>
    </span></span><span>    <span>type<span>="text"</span>
    </span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
    </span></span><span>    <span>placeholder<span>="Enter the repository's URL"</span>
    </span></span><span>    <span>aria-label<span>="Repository URL"</span>
    </span></span><span>    <span><span>bind:value</span><span>={repo}</span>
    </span></span><span>  <span>/></span>
    </span>  <span><span><span><button</span>
    </span></span><span>    <span>class<span>="mt-2 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
    </span></span><span>    <span>></span>Track repository<span><span></button</span>
    </span></span><span>  <span>></span>
    </span>
      <span><span><span><h2</span> class<span>="mt-4 text-2xl"</span>></span>Tracked repositories<span><span></h2</span>></span>
    </span>  <span><span><span><ul</span> class<span>="m-2 list-decimal"</span>></span>
    </span>    <span><!-- We'll use a loop to automatically add repositories here later on. -->
    </span>    <span><span><span><li</span> class<span>="py-1 flex items-center justify-between"</span>></span>
    </span>      <span><span><span><a</span> class<span>="text-gray-500 hover:underline"</span> href<span>="https://github.com/test/test"</span>
    </span></span><span>        <span>></span>https://github.com/test/test<span><span></a</span>
    </span></span><span>      <span>></span>
    </span>      <button  on:click={() => untrack("")}
            >Untrack<span><span><span></button</span>
    </span></span><span>      <span>></span>
    </span>    <span><span><span></li</span>></span>
    </span>  <span><span><span></ul</span>></span>
    </span><span><span><span></form</span>></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    在Svelte中创建带有推送通知的GitHub跟踪器>现在剩下的就是在前端获取此功能。在src/lib/usernameprompt.svelte中,在提交功能中,首先需要将请求发送到云功能,然后将用户名放入LocalStorage,因此我们知道用户已认证。您可以使用fetch函数发送请求:

    >我们正在重新加载页面,因为在app.svelte中,加载页面后,我们需要检查localStorage中是否有用户名。如果有的话,我们可以跳过USERNAME PROMPT屏幕。为此,请在app.svelte的脚本标签中添加此代码:
    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>// import UsernamePrompt from "./lib/UsernamePrompt.svelte";
    </span></span></span><span><span>  <span>import <span>Tracker</span> from "./lib/Tracker.svelte";
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><!-- <UsernamePrompt /> -->
    </span><span><span><span><Tracker</span> /></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    >上面的代码将检查一个用户名的localStorage,并将其设置为true(如果存在)。接下来,我们要做的就是更新DOM。就在app.svelte的脚本标签下,添加以下内容:
    <span>const { MongoClient } = require("mongodb");
    </span>
    <span>const mongo = new MongoClient(process.env.MONGODB_URL);
    </span>
    <span>// Export the connection promise
    </span><span>export default mongo.connect();
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    跟踪和取消跟踪存储库
    <span>{
    </span>  <span>"type": "commonjs"
    </span><span>}
    </span>
    登录后复制
    登录后复制
    登录后复制

    >现在,让我们为跟踪器的实际跟踪功能添加功能。如果您打开Tracker.Svelte,您会注意到有两个功能 - track()和untrack()。这些函数应分别通过将其添加到数据库中来跟踪和解开存储库。

    >,但在此之前,您需要添加更多云功能。一个可以跟踪存储库,另一个用于取消轨道,另一个用于获取用户的跟踪存储库。

    >

    让我们一个一个一个。

    >跟踪存储库

    创建文件API/TRACKREPO.JS。这将映射到 /api /trackRepo:

    用户想要跟踪存储库时,他们将以存储库的名称及其在身体中的用户名来向此功能发送邮政请求。该功能将在用户集合的TrackEdRepos字段中添加存储库的名称。添加一些代码以从身体中获取这些字段:

    <span># Don't forget to CD!
    </span><span>cd api
    </span><span>npm i mongodb # or use yarn
    </span>
    登录后复制
    登录后复制
    登录后复制

    >最后,添加代码通过将其添加到数据库中来跟踪存储库:

    <span>const mongoPromise = require("../src/lib/mongo");
    </span><span>// All cloud functions must export a function that takes a req and res object.
    </span><span>// These objects are similar to their express counterparts.
    </span>module<span>.exports = async (req<span>, res</span>) => {
    </span>  <span>// TODO
    </span><span>};
    </span>
    登录后复制
    登录后复制

    这就是API/TRACKREPO.JS应该看起来的方式:

    >
    module<span>.exports = async (req<span>, res</span>) =>
    </span>  <span>// Wait for the client to connect
    </span>  <span>const mongo = await mongoPromise;
    </span><span>}
    </span>
    登录后复制
    登录后复制

    现在是时候在跟踪器中使用此功能了。打开src/lib/tracker.svelte,然后更改track()函数:

    >
    <span>// ...
    </span><span>const { username } = req.body;
    </span>
    <span>// Check if the username is valid
    </span><span>if (typeof username !== "string" || !username.trim()) {
    </span>  res<span>.status(400).json({ message: "Please send the username" });
    </span>  <span>return;
    </span><span>}
    </span>
    登录后复制

    >现在,当您在输入中输入存储库并单击轨道时,它应该保存在数据库中。

    未跟踪存储库

    >让我们添加一个云功能以解开存储库。创建文件API/UNTRACKREPO.JS。这将映射到 /api /untrackrepo:

    <span>npm init vite
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    此云功能的请求主体将与TrackRepo函数的请求主体相同 - 用户的用户名和repo:

    npx svelte-add tailwindcss
    
    <span># Install packages
    </span><span>yarn install # or npm install
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    接下来,来自用户的TrackEdRepos删除存储库的代码来了:

    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>let username = "";
    </span></span></span><span><span>  <span>async function submit() {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><form</span>
    </span></span><span>  <span><span>on:submit|preventDefault</span><span>="{submit}"</span>
    </span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
    </span></span><span><span>></span>
    </span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>Enter a username<span><span></h1</span>></span>
    </span>  <span><span><span><p</span> class<span>="text-center text-xl m-4"</span>></span>Enter a username to use this tracker<span><span></p</span>></span>
    </span>
      <span><span><span><input</span>
    </span></span><span>    <span>type<span>="text"</span>
    </span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
    </span></span><span>    <span>placeholder<span>="Username"</span>
    </span></span><span>    <span>aria-label<span>="Username"</span>
    </span></span><span>    <span><span>bind:value</span><span>="{username}"</span>
    </span></span><span>  <span>/></span>
    </span>
      <span><span><span><button</span>
    </span></span><span>    <span>class<span>="mt-4 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
    </span></span><span>  <span>></span>
    </span>    Submit
      <span><span><span></button</span>></span>
    </span><span><span><span></form</span>></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    这就是API/UNTRACKREPO.JS应该看起来的方式:

    >
    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>import <span>UsernamePrompt</span> from "./lib/UsernamePrompt.svelte";
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><UsernamePrompt</span> /></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    现在是时候在前端使用此云功能了。在src/lib/tracker.svelte的untrack()函数中,添加此代码:

    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>let repo = "";
    </span></span></span><span><span>  <span>function track() {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span>
    </span></span><span><span>  <span>function untrack(repo) {
    </span></span></span><span><span>    <span>// TODO
    </span></span></span><span><span>  <span>}
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><span><span><form</span>
    </span></span><span>  <span><span>on:submit|preventDefault</span><span>={track}</span>
    </span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
    </span></span><span><span>></span>
    </span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>GitHub tracker<span><span></h1</span>></span>
    </span>
      <span><span><span><input</span>
    </span></span><span>    <span>type<span>="text"</span>
    </span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
    </span></span><span>    <span>placeholder<span>="Enter the repository's URL"</span>
    </span></span><span>    <span>aria-label<span>="Repository URL"</span>
    </span></span><span>    <span><span>bind:value</span><span>={repo}</span>
    </span></span><span>  <span>/></span>
    </span>  <span><span><span><button</span>
    </span></span><span>    <span>class<span>="mt-2 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
    </span></span><span>    <span>></span>Track repository<span><span></button</span>
    </span></span><span>  <span>></span>
    </span>
      <span><span><span><h2</span> class<span>="mt-4 text-2xl"</span>></span>Tracked repositories<span><span></h2</span>></span>
    </span>  <span><span><span><ul</span> class<span>="m-2 list-decimal"</span>></span>
    </span>    <span><!-- We'll use a loop to automatically add repositories here later on. -->
    </span>    <span><span><span><li</span> class<span>="py-1 flex items-center justify-between"</span>></span>
    </span>      <span><span><span><a</span> class<span>="text-gray-500 hover:underline"</span> href<span>="https://github.com/test/test"</span>
    </span></span><span>        <span>></span>https://github.com/test/test<span><span></a</span>
    </span></span><span>      <span>></span>
    </span>      <button  on:click={() => untrack("")}
            >Untrack<span><span><span></button</span>
    </span></span><span>      <span>></span>
    </span>    <span><span><span></li</span>></span>
    </span>  <span><span><span></ul</span>></span>
    </span><span><span><span></form</span>></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    >您会注意到它与Track()函数非常相似,因为它实际上是相同的;只是URL已更新。您还不能真正对此进行测试,因为我们没有显示跟踪存储库的列表,所以让我们解决这个问题。

    >

    >列表跟踪的存储库

    这部分非常简单。您只需要从数据库中获取用户的跟踪存储库,然后在前端显示它。创建一个云函数API/listrepos.js,然后向其添加以下代码:>

    <span><span><span><script</span>></span><span>
    </span></span><span><span>  <span>// import UsernamePrompt from "./lib/UsernamePrompt.svelte";
    </span></span></span><span><span>  <span>import <span>Tracker</span> from "./lib/Tracker.svelte";
    </span></span></span><span><span></span><span><span></script</span>></span>
    </span>
    <span><!-- <UsernamePrompt /> -->
    </span><span><span><span><Tracker</span> /></span>
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    >由于将使用HTTP获取请求来调用云功能,因此您无法将其放置在其中,因此我们使用查询字符串来传递用户名;而且由于user.trackedrepos可能为null,因此我们确保返回数组。接下来,是时候在前端使用此云功能了!在src/lib/tracker.svelte文件中创建一个称为fetchrepos的异步函数。此功能将负责使用我们刚刚创建的云功能从数据库中获取用户的跟踪存储库:>

    >安装组件时我们需要获取此功能。这可以使用Svelte中的OnMount钩子完成。安装组件时,我想将上述函数的返回值设置为一个称为TrackEdrepos的变量,因此我们可以在DOM中使用它:
    <span>const { MongoClient } = require("mongodb");
    </span>
    <span>const mongo = new MongoClient(process.env.MONGODB_URL);
    </span>
    <span>// Export the connection promise
    </span><span>export default mongo.connect();
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制

    >现在我们可以访问用户的跟踪存储库,让我们在Tracker.Svelte中更新HTML模板以显示跟踪存储库的准确列表:
    <span>{
    </span>  <span>"type": "commonjs"
    </span><span>}
    </span>
    登录后复制
    登录后复制
    登录后复制
    >

    >我们仍然必须重新加载页面才能查看任何更改。让我们每次单击轨道或UNTRACK按钮时都更新DOM来解决该问题:>
    <span># Don't forget to CD!
    </span><span>cd api
    </span><span>npm i mongodb # or use yarn
    </span>
    登录后复制
    登录后复制
    登录后复制

    >这是Tracker.Svelte应该看起来的样子:

    <span>const mongoPromise = require("../src/lib/mongo");
    </span><span>// All cloud functions must export a function that takes a req and res object.
    </span><span>// These objects are similar to their express counterparts.
    </span>module<span>.exports = async (req<span>, res</span>) => {
    </span>  <span>// TODO
    </span><span>};
    </span>
    登录后复制
    登录后复制

    >这是该应用现在应该如何显示的屏幕截图。

    module<span>.exports = async (req<span>, res</span>) =>
    </span>  <span>// Wait for the client to connect
    </span>  <span>const mongo = await mongoPromise;
    </span><span>}
    </span>
    登录后复制
    登录后复制

    >步骤4:使应用程序可安装

    在Svelte中创建带有推送通知的GitHub跟踪器>推送通知仅在

    >安装的应用程序

    上支持。是的,您可以使用支持的浏览器

    来安装Web应用程序作为常规应用程序 - 即,Chrome和其他基于铬的浏览器。

    为了使应用程序可安装,您需要将其转换为渐进的Web应用程序。这是一个三步的过程:

    1. 添加服务工作者
    2. 使您的应用程序脱机
    3. 添加清单。
    如果完成了所有三个步骤,则访问应用程序时的地址栏上会出现一个安装按钮。

    添加服务工作者

    服务工作者是可以在浏览器主线程中运行的JavaScript文件。这使他们可以执行诸如脱机运行,在后台运行和下载大文件之类的事情。它们主要用于缓存请求和聆听活动,我们将要做的这两个事件。>

    >要添加服务工作者,您需要添加一个公开可用的JavaScript文件,例如任何CSS文件。这个名称并不重要,但通常被称为service-worker.js或sw.js。该文件应像您的CSS一样公开提供,因此将其放入公共目录中。

    服务工作者通过听事件来工作。对于缓存文件,因此您的应用程序脱机工作,您将收听安装,激活和获取事件。安装服务工作者安装时,安装事件被调用。服务工作者运行时,请调用激活事件,并且每当提出网络请求时,就会调用Fetch事件。可以使用self.addeventlistener()添加活动听众。让我们创建一个public/service-worker.js文件,然后添加以下代码:>

    >剩下的就是注册此服务工作者。我们将在app.svelte的Onmount函数中执行此操作。在回调的末尾添加此代码:

    <span>npm init vite
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    上面的代码首先检查浏览器中的服务工作者支持,然后注册我们的服务工作者。必须指出的是,寄存器()函数中的路径是相对于您的域

    >,

    >而不是
    npx svelte-add tailwindcss
    
    <span># Install packages
    </span><span>yarn install # or npm install
    </span>
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    登录后复制
    的路径,这意味着应该在http上访问服务工作者:// localhost:3000/service-worker.js,因为它在公共目录中

    现在,如果您>重新加载页面并打开控制台,则应查看上述消息。> 使我们的应用程序脱机

    要使应用程序脱机工作,您需要使用服务工作者来缓存其内容。由于我们的应用程序提出了云功能的要求,因此当没有网络时,它实际上无法做太多。因此,我们没有显示该应用程序的缓存,无功能的版本,而是显示一个表明我们离线的页面。创建一个public/offline.html文件,并将以下代码放入其中:> >随时可以根据需要自定义此页面。您现在需要缓存此页面。缓存也是一个三步过程,它使用了我们听过的三个服务工作者事件。以下是它的工作方式:

    >

    使用CACHE.ADD打开缓存,并将所需的路由添加到缓存中。这发生在安装期间。

  4. 删除了较旧的高速缓存,因此只有最新的保存在用户的计算机中。这利用了较少的存储空间。这发生在激活过程中。
  5. 我们拦截了任何网络请求,并检查这些请求是否为

    页面navigations - 也就是说,更改路由。如果请求成功,一切都很好,但是如果请求失败,我们将向用户提供脱机.html页面。这发生在获取期间。

    >让我们实现第一步。打开服务工作者文件,然后更改安装事件的处理程序:
  6. >

event.waituntil()是一个类似于等待关键字的函数。 AddEventListener的回调不能异步,因此要实现该功能,我们应该使用event.waituntil()并通过它来承诺,以便期待诺言。

> self.skipwaiting()告诉浏览器我们完成了安装过程,因此请激活服务工作者。说到激活,现在添加代码以删除任何旧的缓存:>
<span>npm init vite
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

>,应该将offline.html页面缓存。要仔细检查,请按

f12

打开开发人员工具,然后选择“应用程序”选项卡。在侧边栏上,应该有一个缓存存储选项卡。单击它,您应该注意到 /offline.html。

npx svelte-add tailwindcss

<span># Install packages
</span><span>yarn install # or npm install
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

现在,当没有网络时,剩下要做的就是服务此文件:>

event.respondwith()函数将使用传递给它的任何响应对象响应网络获取请求。在这种情况下,我们首先提取请求,如果请求失败,这很可能是由于Internet问题,我们将发送earlline.html页面,该页面由服务工作者缓存。 在Svelte中创建带有推送通知的GitHub跟踪器现在刷新页面并关闭您的Wi-Fi或以太网。现在,当您刷新时,您应该看到我们的离线页面,而不是默认的Chrome“无网络”页面。不幸的是,此脱机页面没有恐龙游戏,但确实使我们可以将应用程序安装为PWA。

这是服务工作者应该看起来的样子:

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>let username = "";
</span></span></span><span><span>  <span>async function submit() {
</span></span></span><span><span>    <span>// TODO
</span></span></span><span><span>  <span>}
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><span><span><form</span>
</span></span><span>  <span><span>on:submit|preventDefault</span><span>="{submit}"</span>
</span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
</span></span><span><span>></span>
</span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>Enter a username<span><span></h1</span>></span>
</span>  <span><span><span><p</span> class<span>="text-center text-xl m-4"</span>></span>Enter a username to use this tracker<span><span></p</span>></span>
</span>
  <span><span><span><input</span>
</span></span><span>    <span>type<span>="text"</span>
</span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
</span></span><span>    <span>placeholder<span>="Username"</span>
</span></span><span>    <span>aria-label<span>="Username"</span>
</span></span><span>    <span><span>bind:value</span><span>="{username}"</span>
</span></span><span>  <span>/></span>
</span>
  <span><span><span><button</span>
</span></span><span>    <span>class<span>="mt-4 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
</span></span><span>  <span>></span>
</span>    Submit
  <span><span><span></button</span>></span>
</span><span><span><span></form</span>></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
添加清单。 标签

链接到您的网站,就像您链接CSS文件一样。让我们为我们的应用程序添加清单。随意使用发电机:

>

您需要为应用程序下载一堆图标。这些图标的大小不同,并且由不同的操作系统使用。您可以从源代码存储库或使用此链接下载它们。确保将zip文件提取到公共/图标。

>接下来,您需要将清单和图标添加到index.html文件中。您可以通过将以下代码放入其中:

>通过按下
<span>npm init vite
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
f12

的打开Chrome’d开发人员工具,然后转到灯塔选项卡并创建一个新的审核。现在,您应该在PWA部分获得“可安装”分数。这意味着您已成功将网站转换为WebApp,现在可以通过单击地址栏上的按钮来安装它。

在Svelte中创建带有推送通知的GitHub跟踪器步骤5:订阅以推送通知

>在我们发送推送通知之前,我们需要获得用户的许可。您可以使用notification.requestpermission()方法进行此操作。此方法是

>异步

,并且返回可以等于默认值(拒绝和授予)的A字符串。当用户按下X,按下拒绝或按NOTIFIFICAN提示符允许时,将返回这些。我们将使用app.svelte中的onmount钩子调用此功能:> >您现在应该弹出一个弹出窗口,要求您在应用中允许通知。现在,我们已经有权发送通知,让我们使用服务工作者订阅推动事件。这可以使用服务工作者的PusphManager.subscribe()函数来完成。您可以在服务工作者本身或在app.svelte注册服务工作者之后执行此操作。我会选择后者,因此,如果您想执行相同的操作,只需替换Navigator.ServiceWorker.Register在OnMount中使用以下代码:>

npx svelte-add tailwindcss

<span># Install packages
</span><span>yarn install # or npm install
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
如果打开控制台,您会注意到一个错误,说applicationserverkey缺少。推送通知需要服务器来发送推送消息,并且这些服务器使用VAPID键进行身份验证。这些键标识服务器,并让浏览器知道推送消息有效。我们将使用Vercel Cloud函数发送推送消息,因此我们需要进行设置。>

创建推动消息服务器

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>let username = "";
</span></span></span><span><span>  <span>async function submit() {
</span></span></span><span><span>    <span>// TODO
</span></span></span><span><span>  <span>}
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><span><span><form</span>
</span></span><span>  <span><span>on:submit|preventDefault</span><span>="{submit}"</span>
</span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
</span></span><span><span>></span>
</span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>Enter a username<span><span></h1</span>></span>
</span>  <span><span><span><p</span> class<span>="text-center text-xl m-4"</span>></span>Enter a username to use this tracker<span><span></p</span>></span>
</span>
  <span><span><span><input</span>
</span></span><span>    <span>type<span>="text"</span>
</span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
</span></span><span>    <span>placeholder<span>="Username"</span>
</span></span><span>    <span>aria-label<span>="Username"</span>
</span></span><span>    <span><span>bind:value</span><span>="{username}"</span>
</span></span><span>  <span>/></span>
</span>
  <span><span><span><button</span>
</span></span><span>    <span>class<span>="mt-4 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
</span></span><span>  <span>></span>
</span>    Submit
  <span><span><span></button</span>></span>
</span><span><span><span></form</span>></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
>我们将使用Web-Push NPM软件包来帮助我们生成密钥并发送推送事件。要安装它,请将其CD到API文件夹并运行以下内容:

>

请记住将CD到API文件夹,否则Web-Push软件包将安装在Svelte App中。

要发送推送通知,您需要生成一个公共和私有VAPID密钥对。为此,请使用节点命令打开节点reve Repled并运行以下命令:>

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>import <span>UsernamePrompt</span> from "./lib/UsernamePrompt.svelte";
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><span><span><UsernamePrompt</span> /></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
>复制这两个键,并将它们作为环境变量存储在Vercel上。确保称他们为令人难忘的东西,例如vapid_private_key和vapid_public_key。

现在,我们可以开始在云功能上进行工作。创建文件api/vapidkeys.js。该文件将负责将publicvapid键发送给客户端。您应该永远不要共享私有VAPID密钥。在API/vapidkeys.js中,首先我们需要初始化web-push: >确保用vercel应用程序的域替换your_vercel_domain。接下来,让我们导出一个函数以将公共VAPID密钥返回请求者:>

<span>npm init vite
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
>完成此操作,您现在可以更新app.svelte中的onmount函数以首先获取云功能以获取公共密钥,然后在订阅函数中使用公共密钥:>

请注意,如果
npx svelte-add tailwindcss

<span># Install packages
</span><span>yarn install # or npm install
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
>我们尚未订阅推送通知,我们只能获取Vapid键

。如果打开控制台,则应查看已记录到控制台的订阅。>

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>let username = "";
</span></span></span><span><span>  <span>async function submit() {
</span></span></span><span><span>    <span>// TODO
</span></span></span><span><span>  <span>}
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><span><span><form</span>
</span></span><span>  <span><span>on:submit|preventDefault</span><span>="{submit}"</span>
</span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
</span></span><span><span>></span>
</span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>Enter a username<span><span></h1</span>></span>
</span>  <span><span><span><p</span> class<span>="text-center text-xl m-4"</span>></span>Enter a username to use this tracker<span><span></p</span>></span>
</span>
  <span><span><span><input</span>
</span></span><span>    <span>type<span>="text"</span>
</span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
</span></span><span>    <span>placeholder<span>="Username"</span>
</span></span><span>    <span>aria-label<span>="Username"</span>
</span></span><span>    <span><span>bind:value</span><span>="{username}"</span>
</span></span><span>  <span>/></span>
</span>
  <span><span><span><button</span>
</span></span><span>    <span>class<span>="mt-4 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
</span></span><span>  <span>></span>
</span>    Submit
  <span><span><span></button</span>></span>
</span><span><span><span></form</span>></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

提供的终点对我们非常重要。此终点将使我们能够使用Web-Push通知此用户。让我们创建一个云功能以将此端点存储在数据库中。创建文件API/StoreEndpoint.js:

>让我们从身体中获取订阅和用户名:> 在Svelte中创建带有推送通知的GitHub跟踪器

>让我们将其添加到数据库中:

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>import <span>UsernamePrompt</span> from "./lib/UsernamePrompt.svelte";
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><span><span><UsernamePrompt</span> /></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
>这是最终云功能的外观:

每次我们订阅推送通知时,都应调用此功能。让我们使用一个Svelte的反应块来调用此云功能,每当子变量具有值
<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>let repo = "";
</span></span></span><span><span>  <span>function track() {
</span></span></span><span><span>    <span>// TODO
</span></span></span><span><span>  <span>}
</span></span></span><span><span>
</span></span><span><span>  <span>function untrack(repo) {
</span></span></span><span><span>    <span>// TODO
</span></span></span><span><span>  <span>}
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><span><span><form</span>
</span></span><span>  <span><span>on:submit|preventDefault</span><span>={track}</span>
</span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
</span></span><span><span>></span>
</span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>GitHub tracker<span><span></h1</span>></span>
</span>
  <span><span><span><input</span>
</span></span><span>    <span>type<span>="text"</span>
</span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
</span></span><span>    <span>placeholder<span>="Enter the repository's URL"</span>
</span></span><span>    <span>aria-label<span>="Repository URL"</span>
</span></span><span>    <span><span>bind:value</span><span>={repo}</span>
</span></span><span>  <span>/></span>
</span>  <span><span><span><button</span>
</span></span><span>    <span>class<span>="mt-2 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
</span></span><span>    <span>></span>Track repository<span><span></button</span>
</span></span><span>  <span>></span>
</span>
  <span><span><span><h2</span> class<span>="mt-4 text-2xl"</span>></span>Tracked repositories<span><span></h2</span>></span>
</span>  <span><span><span><ul</span> class<span>="m-2 list-decimal"</span>></span>
</span>    <span><!-- We'll use a loop to automatically add repositories here later on. -->
</span>    <span><span><span><li</span> class<span>="py-1 flex items-center justify-between"</span>></span>
</span>      <span><span><span><a</span> class<span>="text-gray-500 hover:underline"</span> href<span>="https://github.com/test/test"</span>
</span></span><span>        <span>></span>https://github.com/test/test<span><span></a</span>
</span></span><span>      <span>></span>
</span>      <button  on:click={() => untrack("")}
        >Untrack<span><span><span></button</span>
</span></span><span>      <span>></span>
</span>    <span><span><span></li</span>></span>
</span>  <span><span><span></ul</span>></span>
</span><span><span><span></form</span>></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
>和

的iSloggedIn变量时。在app.svelte中的<script>标签结束之前,添加此代码 </script>

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>// import UsernamePrompt from "./lib/UsernamePrompt.svelte";
</span></span></span><span><span>  <span>import <span>Tracker</span> from "./lib/Tracker.svelte";
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><!-- <UsernamePrompt /> -->
</span><span><span><span><Tracker</span> /></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
>刷新页面,您应该看到当前浏览器的按下端点和键存储在订阅对象中的mongoDB数据库中。>您要做的就是处理服务工作者中的推送事件,并创建一个云功能以检查GitHub是否有新问题和PRS。

>让我们先做后者。创建一个新的云功能API/fetchgh.js。此功能将负责检查github并发送推送通知:
<span>const { MongoClient } = require("mongodb");
</span>
<span>const mongo = new MongoClient(process.env.MONGODB_URL);
</span>
<span>// Export the connection promise
</span><span>export default mongo.connect();
</span>
登录后复制
登录后复制
登录后复制
登录后复制
>

>让我们从数据库中获取所有用户,因此我们知道要获取什么回购:>

接下来,创建两个变量来存储当前获取的存储库,以及具有任何新问题或PRS的存储库:>
<span>npm init vite
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

对于每个用户,让我们查看其跟踪的存储库中的任何新问题。为了确保仅检查一个存储库一次,我们将将存储库添加到已经取方的雷神中,并将添加所有具有新问题的存储库中的存储库。为此,我们需要循环浏览用户数组中的每个用户,并获取以获取的存储库列表。这将通过检查其TrackedRepos中的任何重复项来完成。完成此操作后,我们将为每个存储库调用FetchRepo功能。 fetchrepo将返回布尔值 - 如果有新问题,则为false,否则:

>
npx svelte-add tailwindcss

<span># Install packages
</span><span>yarn install # or npm install
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

>由于fetchrepo会异步,所以我使用地图每次都返回承诺,并使用Promise.All等待所有诺言。这是因为for循环是异步的。如果不期待承诺,变量可能是不确定的,请务必等待承诺!

> 现在,用于fetchrepo函数。此功能将获得我们最后一次从数据库中检查GitHub API的时间。这只能从Github获取最新问题。然后,它以获取任何新问题的GitHub API,如果有的话,将返回一个布尔值:

>

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>let username = "";
</span></span></span><span><span>  <span>async function submit() {
</span></span></span><span><span>    <span>// TODO
</span></span></span><span><span>  <span>}
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><span><span><form</span>
</span></span><span>  <span><span>on:submit|preventDefault</span><span>="{submit}"</span>
</span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
</span></span><span><span>></span>
</span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>Enter a username<span><span></h1</span>></span>
</span>  <span><span><span><p</span> class<span>="text-center text-xl m-4"</span>></span>Enter a username to use this tracker<span><span></p</span>></span>
</span>
  <span><span><span><input</span>
</span></span><span>    <span>type<span>="text"</span>
</span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
</span></span><span>    <span>placeholder<span>="Username"</span>
</span></span><span>    <span>aria-label<span>="Username"</span>
</span></span><span>    <span><span>bind:value</span><span>="{username}"</span>
</span></span><span>  <span>/></span>
</span>
  <span><span><span><button</span>
</span></span><span>    <span>class<span>="mt-4 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
</span></span><span>  <span>></span>
</span>    Submit
  <span><span><span></button</span>></span>
</span><span><span><span></form</span>></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
>完成此操作后,我们需要向跟踪具有任何新问题的存储库的任何用户发送推送通知。这可以使用Web-Push完成。将这些代码行添加到导出函数的末尾:

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>import <span>UsernamePrompt</span> from "./lib/UsernamePrompt.svelte";
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><span><span><UsernamePrompt</span> /></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
首先,我们需要检查任何用户的跟踪存储库是否有新问题。这可以使用阵列。一种方法。 array.some()确定指定的回调函数是否返回数组的任何元素,因此我们可以轻松地使用它来检查:

>

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>let repo = "";
</span></span></span><span><span>  <span>function track() {
</span></span></span><span><span>    <span>// TODO
</span></span></span><span><span>  <span>}
</span></span></span><span><span>
</span></span><span><span>  <span>function untrack(repo) {
</span></span></span><span><span>    <span>// TODO
</span></span></span><span><span>  <span>}
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><span><span><form</span>
</span></span><span>  <span><span>on:submit|preventDefault</span><span>={track}</span>
</span></span><span>  <span>class<span>="mx-auto min-w-[350px] max-w-[1100px] w-[50%] border border-gray-500 rounded my-4 px-6 py-4"</span>
</span></span><span><span>></span>
</span>  <span><span><span><h1</span> class<span>="text-center text-3xl m-4"</span>></span>GitHub tracker<span><span></h1</span>></span>
</span>
  <span><span><span><input</span>
</span></span><span>    <span>type<span>="text"</span>
</span></span><span>    <span>class<span>="rounded px-4 py-2 border border-gray-300 w-full outline-none"</span>
</span></span><span>    <span>placeholder<span>="Enter the repository's URL"</span>
</span></span><span>    <span>aria-label<span>="Repository URL"</span>
</span></span><span>    <span><span>bind:value</span><span>={repo}</span>
</span></span><span>  <span>/></span>
</span>  <span><span><span><button</span>
</span></span><span>    <span>class<span>="mt-2 border border-transparent bg-blue-500 text-white rounded px-4 py-2 w-full"</span>
</span></span><span>    <span>></span>Track repository<span><span></button</span>
</span></span><span>  <span>></span>
</span>
  <span><span><span><h2</span> class<span>="mt-4 text-2xl"</span>></span>Tracked repositories<span><span></h2</span>></span>
</span>  <span><span><span><ul</span> class<span>="m-2 list-decimal"</span>></span>
</span>    <span><!-- We'll use a loop to automatically add repositories here later on. -->
</span>    <span><span><span><li</span> class<span>="py-1 flex items-center justify-between"</span>></span>
</span>      <span><span><span><a</span> class<span>="text-gray-500 hover:underline"</span> href<span>="https://github.com/test/test"</span>
</span></span><span>        <span>></span>https://github.com/test/test<span><span></a</span>
</span></span><span>      <span>></span>
</span>      <button  on:click={() => untrack("")}
        >Untrack<span><span><span></button</span>
</span></span><span>      <span>></span>
</span>    <span><span><span></li</span>></span>
</span>  <span><span><span></ul</span>></span>
</span><span><span><span></form</span>></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
>最后,我们发送通知:

<span><span><span><script</span>></span><span>
</span></span><span><span>  <span>// import UsernamePrompt from "./lib/UsernamePrompt.svelte";
</span></span></span><span><span>  <span>import <span>Tracker</span> from "./lib/Tracker.svelte";
</span></span></span><span><span></span><span><span></script</span>></span>
</span>
<span><!-- <UsernamePrompt /> -->
</span><span><span><span><Tracker</span> /></span>
</span>
登录后复制
登录后复制
登录后复制
登录后复制
这是云功能应该看起来的方式:

<span>const { MongoClient } = require("mongodb");
</span>
<span>const mongo = new MongoClient(process.env.MONGODB_URL);
</span>
<span>// Export the connection promise
</span><span>export default mongo.connect();
</span>
登录后复制
登录后复制
登录后复制
登录后复制
聆听推动事件

>剩下要做的就是聆听服务工作者中的推动事件。打开服务工作者并添加下面的代码:

<span>{
</span>  <span>"type": "commonjs"
</span><span>}
</span>
登录后复制
登录后复制
登录后复制
>调用云功能时,也许使用卷发时,您应该在浏览器控制台中查看新问题。这真的不是很有帮助,所以让它发出通知:

>

<span># Don't forget to CD!
</span><span>cd api
</span><span>npm i mongodb # or use yarn
</span>
登录后复制
登录后复制
登录后复制
>从mongodb删除收集的收集,然后再次调用云功能。现在,您应该从Web浏览器中收到通知。

在Svelte中创建带有推送通知的GitHub跟踪器

使用Vercel部署应用程序。或通过推动GitHub,将应用程序作为PWA安装,然后通过访问https:// your_vercel_app/api/fetchgh来运行云功能,即使您尚未打开应用程序!

,也应该收到通知。

如果您没有收到通知,或者从Web推动中获得410错误,请确保在询问时允许在提示符中永远允许通知。

>

在Svelte中创建带有推送通知的GitHub跟踪器

步骤6:创建一个cron作业

如果我们必须手动调用云功能,对跟踪器并不是真正的跟踪器,对吗?让我们使用EasyCron每小时自动调用云功能。

>

>前往您的EasyCron仪表板,创建一个新的Cron作业。对于URL,请输入https:// your_vercel_domain/api/fetchgh,然后选择一个间隔。我每小时都会去,但请随时自定义。

>

在Svelte中创建带有推送通知的GitHub跟踪器

结论

>这样,您每次在任何跟踪的存储库中都有新问题/PR时,您应该收到通知。如果您在任何地方都卡住了,请随时查看源代码或实时版本。

>经常询问的问题(常见问题解答)关于在Svelte

中创建带有推送通知的GitHub跟踪器

什么是svelte,为什么我应该使用它来创建github跟踪器?

svelte是现代的javaScript编译器,它允许您编写易于理解的JavaScript代码,然后将其编译为高效的代码直接在浏览器中运行。它提供了比其他JavaScript框架(如React或Vue)更简单,更直观的编程模型,并导致加载时间更快,性能更好。创建GitHub跟踪器时,使用Svelte可以使您的代码清洁,更易于维护和更有效。内置反应性系统。该系统允许您定义反应性语句,这些语句每当应用程序的状态更改时会自动更新。当发生更改时,例如将新提交推向GitHub存储库时,反应性语句可以触发推送通知以告知用户更改。

我可以使用Svelte跟踪多个GitHub存储库吗?>

>我如何自定义Sevelte通知的外观?可以使用CSS自定义Svelte中的通知。 Svelte允许您编写仅适用于定义的组件的范围CSS。这意味着您可以在不影响其余应用程序的情况下为您的推送通知创建独特的样式。

>

>我可以与其他JavaScript框架或库一起使用Svelte? JavaScript框架或库。但是,Svelte的主要优点之一是它的简单性和效率,因此将其与其他框架或图书馆一起使用可能会否定其中一些好处。如果可能的话,最好自行使用Svelte。

>在Svelte中创建GITHUB跟踪器时,如何处理错误?

>使用JavaScript代码中的try/catch块可以在Svelte中进行错误处理。例如,如果从GitHub API获取数据时发生错误,则可以捕获错误并向用户显示有用的消息。

>

我可以使用SVELTE创建私人存储库的GitHub Tracker吗? >

是的,您可以使用Svelte为私人存储库创建GitHub跟踪器。您需要使用个人访问令牌与GitHub API进行身份验证,该令牌可以从您的github帐户设置中生成。

如何在Svelte中测试我的GitHub Tracker?可以使用各种JavaScript测试库,例如开玩笑或摩卡咖啡来完成。这些库允许您为组件和反应性语句编写测试,以确保它们正常工作。

我可以将我的Svelte Github跟踪器部署到服务器上吗?

是的,您可以部署Svelte GitHub跟踪器到服务器。 Svelte将您的代码编译到普通的JavaScript,CSS和HTML,可以由任何静态文件服务器提供。

>

如何在Svelte或GitHub API更改时如何更新我的GitHub Tracker?当Svelte或GitHub API更改时,您需要相应地更新GitHub跟踪器。这可能涉及更新您的Svelte代码以使用新功能或语法,或更新API调用以匹配GitHub API中的更改。重要的是要定期检查更新,以确保您的github跟踪器继续正常工作。

>

以上是在Svelte中创建带有推送通知的GitHub跟踪器的详细内容。更多信息请关注PHP中文网其他相关文章!

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

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

前端热敏纸小票打印遇到乱码问题怎么办? 前端热敏纸小票打印遇到乱码问题怎么办? Apr 04, 2025 pm 02:42 PM

前端热敏纸小票打印的常见问题与解决方案在前端开发中,小票打印是一个常见的需求。然而,很多开发者在实...

神秘的JavaScript:它的作用以及为什么重要 神秘的JavaScript:它的作用以及为什么重要 Apr 09, 2025 am 12:07 AM

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

谁得到更多的Python或JavaScript? 谁得到更多的Python或JavaScript? Apr 04, 2025 am 12:09 AM

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

JavaScript难以学习吗? JavaScript难以学习吗? Apr 03, 2025 am 12:20 AM

学习JavaScript不难,但有挑战。1)理解基础概念如变量、数据类型、函数等。2)掌握异步编程,通过事件循环实现。3)使用DOM操作和Promise处理异步请求。4)避免常见错误,使用调试技巧。5)优化性能,遵循最佳实践。

如何实现视差滚动和元素动画效果,像资生堂官网那样?
或者:
怎样才能像资生堂官网一样,实现页面滚动伴随的动画效果? 如何实现视差滚动和元素动画效果,像资生堂官网那样? 或者: 怎样才能像资生堂官网一样,实现页面滚动伴随的动画效果? Apr 04, 2025 pm 05:36 PM

实现视差滚动和元素动画效果的探讨本文将探讨如何实现类似资生堂官网(https://www.shiseido.co.jp/sb/wonderland/)中�...

如何使用JavaScript将具有相同ID的数组元素合并到一个对象中? 如何使用JavaScript将具有相同ID的数组元素合并到一个对象中? Apr 04, 2025 pm 05:09 PM

如何在JavaScript中将具有相同ID的数组元素合并到一个对象中?在处理数据时,我们常常会遇到需要将具有相同ID�...

JavaScript的演变:当前的趋势和未来前景 JavaScript的演变:当前的趋势和未来前景 Apr 10, 2025 am 09:33 AM

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

console.log输出结果差异:两次调用为何不同? console.log输出结果差异:两次调用为何不同? Apr 04, 2025 pm 05:12 PM

深入探讨console.log输出差异的根源本文将分析一段代码中console.log函数输出结果的差异,并解释其背后的原因。�...

See all articles