目录
函数文件夹及Node文件
部署到Netlify
CORS跨域资源共享
演示
首页 web前端 css教程 通过NetLify功能使自己有点API

通过NetLify功能使自己有点API

Apr 09, 2025 am 10:37 AM

利用Netlify Functions构建微型API:一个实用案例

Make Yourself a Little API With Netlify Functions

云函数为我们提供了许多巧妙的应用场景。例如,Glitch提供了一个很棒的“友好词汇”包,可以随机生成诸如“快乐的大象”或“行走的树”之类的词组。如果要在JavaScript网页中实现此功能,直接使用这个包可能会有些问题,因为它体积较大(约200KB),包含大量的词汇字典。为了避免增加客户端JavaScript的负担,我们可以利用云函数构建一个微型API。

云函数的优势在于,我们可以将大型资源放在服务器端,而无需将其加载到客户端。Netlify平台使得创建此类API变得非常简单。

以下是一个简单的示例,代码量极少:

函数文件夹及Node文件

在项目根目录下创建文件夹/functions/,并在其中添加文件random.js。此文件将引入friendly-words包,并导出一个函数。该函数的功能是随机获取两个单词,组合在一起并返回结果。

const friendlyWords = require("friendly-words");

exports.handler = function(event, context, callback) {
  const { predicates, objects } = friendlyWords;
  const numberOfPredicates = predicates.length;
  const numbersOfObjects = objects.length;

  const randomPredicate = predicates[Math.floor(Math.random() * numberOfPredicates)];
  const randomObject = objects[Math.floor(Math.random() * numbersOfObjects)];

  const output = `${randomPredicate}-${randomObject}`;

  callback(null, {
    headers: {
      "Access-Control-Allow-Origin": "*"
    },
    statusCode: 200,
    body: output
  });
};
登录后复制

部署到Netlify

我们可以通过netlify.toml文件配置Netlify,告知其函数文件的位置,从而避免使用UI界面进行配置。

[build]
  command = "#"
  functions = "functions/"
登录后复制

当然,也可以在Netlify的设置中直接进行配置。

部署完成后,为其设置一个友好的站点名称,云函数将可以通过一个URL访问。您甚至可以在浏览器中直接查看:

https://www.php.cn/link/8441c6ab9e88ee3764bd79b6d72269a1

现在,我们无需在客户端JavaScript中包含该包,只需访问此URL即可获取所需结果。

CORS跨域资源共享

如果从同样部署在friendly-words.netlify.com的网站访问此URL,则无需考虑CORS问题。但如果需要从其他网站访问,则需要处理CORS。请注意上述Node.js代码中的Access-Control-Allow-Origin设置,它解决了跨域问题。

演示

要使用这个微型API,只需使用fetch函数即可。

Netlify提供了许多使用函数的示例,有兴趣的话可以进一步探索。

在编写此示例的过程中,我参考了Paul Kinlan的文章,该文章实现了几乎相同的功能,并额外提供了一些API功能,值得一看。

以上是通过NetLify功能使自己有点API的详细内容。更多信息请关注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)

VUE 3 VUE 3 Apr 02, 2025 pm 06:32 PM

它的出局!恭喜Vue团队完成了完成,我知道这是一项巨大的努力,而且很长时间。所有新文档也是如此。

使用Redwood.js和Fauna构建以太坊应用 使用Redwood.js和Fauna构建以太坊应用 Mar 28, 2025 am 09:18 AM

随着最近比特币价格超过20k美元的攀升,最近打破了3万美元,我认为值得深入研究创建以太坊

您可以从浏览器获得有效的CSS属性值吗? 您可以从浏览器获得有效的CSS属性值吗? Apr 02, 2025 pm 06:17 PM

我有人写了这个非常合法的问题。 Lea只是在博客上介绍了如何从浏览器中获得有效的CSS属性。那样的是这样。

带有粘性定位的堆叠卡和一点点的杂物 带有粘性定位的堆叠卡和一点点的杂物 Apr 03, 2025 am 10:30 AM

前几天,我发现了科里·金尼文(Corey Ginnivan)网站上的这一点,当您滚动时,彼此之间的卡片堆放集。

在CI/CD上有点 在CI/CD上有点 Apr 02, 2025 pm 06:21 PM

我说的“网站”比“移动应用程序”更合适,但我喜欢Max Lynch的框架:

比较浏览器的响应式设计 比较浏览器的响应式设计 Apr 02, 2025 pm 06:25 PM

这些桌面应用程序中有许多目标是同时在不同的维度上显示您的网站。因此,例如,您可以写作

在WordPress块编辑器中使用Markdown和本地化 在WordPress块编辑器中使用Markdown和本地化 Apr 02, 2025 am 04:27 AM

如果我们需要直接在WordPress编辑器中向用户显示文档,那么最佳方法是什么?

为什么Flex布局中的紫色斜线区域会被误认为是'溢出空间”? 为什么Flex布局中的紫色斜线区域会被误认为是'溢出空间”? Apr 05, 2025 pm 05:51 PM

关于Flex布局中紫色斜线区域的疑问在使用Flex布局时,你可能会遇到一些令人困惑的现象,比如在开发者工具(d...

See all articles