react框架next.js学习之API 路由篇详解教程

正文
next.js 作为最热门的 react 框架,不过这么久了好像国内使用率一直不太高。最近在研究做个小项目正好做下笔记,有兴趣的可以一起来学习。

next.js 首页标榜的 12 个特性之一就是 API routes,简单的说就是可以 next.js 直接写 node 代码作为后端服务来运行。因此我们可以直接使用 next.js 直接维护一个全栈项目,听起来很香的样子。

使用方式
next.js 中使用文件路径作为路由,所以在 API routes 中也是一样,一般的页面文件我们会放在 pages 下,而 API routes 文件我们则需要放在 pages/api 下,emmm,其实我觉得这个设计有点奇怪,为啥不是在外层增加一个 server 或者 api 的文件夹呢,放在 pages 下面感觉怪怪的。而请求时,需要请求对应的 /api/ 下的文件地址,emmm,好吧,真的挺奇怪的。

所以我们要新增一个 API 只需要在 pages/api/ 目录下新建一个文件即可。

API 路由匹配
而 API 的文件命名有三种方式:

pages/api/route.js

pages/api/route/[param].js

pages/api/route/[…slug].js

第一种很好理解,就是会处理发送到 /api/route 的请求,第二种会接受来自 /api/route/xxxx 的请求,并将 xxxx 作为参数放到 param 中,而第三种则是会接收所有的到 /api/route/ 下的请求,比如 /api/route/a/b/c 等。

当请求过来进行匹配时, next.js 将会按照从上到下的优先级来匹配应该处理的路由,比如上面三个文件同时存在,那么发送到 /api/route 的请求将会从被第一个文件所处理,而 /api/route/a 的请求会被第二个文件所处理,剩余的请求才会进入第三个文件中处理。

API 处理
而在处理文件中,会调用默认的导出函数来处理请求:

export default function handler(req, res) {
res.status(200).json({ foo: ‘bar’ });
}
如上代码表示请求的响应体 http 状态码为 200,响应体中是一段 json。

除了 nodejs 原生中包含的一些属性和方法外,next 还在 res 中扩展了以下几个常用的方法:

res.status(code) 响应的 http 状态码
res.json(body) json 响应体
res.send(body) 其它响应体,可以是 string、object、Buffer
res.redirect([status,] path) 重定向
res.revalidate(urlPath) 重新进行校验
而在 req 中则扩展了以下几个常用属性:

req.cookies 请求包含的 cookies
req.query 请求的 query 参数
req.body 请求体
是不是很熟悉,没错就是 express.js 的一些功能。

API 配置
除了 export 默认的处理函数处理请求外,还可 export 一个 config 对象来配置:

export const config = {
api: {
// 请求体处理
bodyParser: {
sizeLimit: ‘1mb’
},
// 响应体的大小限制
responseLimit: ‘8mb’,
// 用于指定请求是否被外部服务处理,这个暂时还没搞清楚是怎么工作的,等研究完了再来更新
externalResolver: true
}
};

边缘计算支持
此外,next.js 的 API routes 还支持最近很火的边缘计算,不过边缘计算的运行时和 node 运行时差异较大,需要注意改动。由于暂时对这方面没有研究,不做过多深入。

自定义 API
除了默认的请求处理,还可以借助外部 server 来处理请求,比如 graphql:

import { createServer } from ‘@graphql-yoga/node’;
const typeDefs = /* GraphQL */ type Query { users: [User!]! } type User { name: String };
const resolvers = {
Query: {
users() {
return [{ name: ‘Nextjs’ }];
}
}
};
const server = createServer({
schema: {
typeDefs,
resolvers
},
endpoint: ‘/api/graphql’
});
export default server;

注意点
另外需要注意的是,如果配置了 pageExtensions,API 文件的命名也会受影响。

还有如果同时存在 pages/api/route/[param].js 和 pages/api/route/[param1].js 不知道会发什么什么,回头有空试试。

总结
使用 next.js 的 API routes,我们可以直接在项目中编写 nodejs 后端代码,轻松完成全栈开发。

再多说几句,经过这么多年的发展,前后端终于分离了,然而最近几年,前端又开始干起后端的活,梦回 php、jsp。古人云的好:风水轮流转,前后不分家。

以上就是react框架next.js学习之API 路由篇详解的详细内容,更多关于react框架next.js API路由的资料请关注其它相关文章!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Tesseract.js是一个基于Google开发的OCR引擎Tesseract的JavaScript库,可以在浏览器和Node.js环境中使用。React是一个由Facebook开发的用于构建用户界面的JavaScript库。在React应用程序中使用Tesseract.js可以使您的应用程序具有识别图像文本的能力。 以下是使用Tesseract.jsReact应用程序中识别图像文本的详细步骤: 1. 首先,您需要安装Tesseract.js库。在您的React应用程序中,可以使用npm或yarn进行安装。使用以下命令进行安装: ``` npm install tesseract.js ``` 2. 接下来,您需要导入Tesseract.js库。您可以使用以下代码将其导入到React组件中: ```javascript import Tesseract from 'tesseract.js'; ``` 3. 然后,您需要创建一个函数,该函数将处理图像并将其传递给Tesseract.js以进行文本识别。您可以使用以下代码创建一个名为recognizeText的函数: ```javascript const recognizeText = async (image) => { const result = await Tesseract.recognize(image, 'eng'); return result.data.text; }; ``` 在上面的代码中,我们将image和'eng'作为参数传递给Tesseract.recognize()方法。image参数是要识别的图像,'eng'参数是要使用的语言。您可以根据需要更改这些参数。 4. 接下来,您需要在React组件中使用recognizeText函数。您可以在React组件的事件处理程序中使用它。例如,以下是一个名为handleImageUpload的事件处理程序,该处理程序将在选择图像时调用recognizeText函数并将结果存储在React状态中: ```javascript handleImageUpload = async (event) => { const file = event.target.files[0]; const reader = new FileReader(); reader.onloadend = async () => { const image = new Image(); image.src = reader.result; image.onload = async () => { const result = await recognizeText(image); this.setState({ text: result }); }; }; reader.readAsDataURL(file); }; ``` 在上面的代码中,我们使用FileReader读取选定的图像文件。然后,我们创建一个新的Image对象,并将其设置为从文件读取的结果。最后,我们在图像加载完成后调用recognizeText函数,并将结果存储在React状态中。 5. 最后,您可以在React组件的render方法中使用识别的文本。例如,以下是一个简单的render方法,该方法将识别的文本显示在屏幕上: ```javascript render() { return ( <div> <input type="file" onChange={this.handleImageUpload} /> <p>{this.state.text}</p> </div> ); } ``` 在上面的代码中,我们将handleImageUpload事件处理程序分配给文件上传输入。然后,我们使用this.state.text显示识别的文本。 这就是在React应用程序中使用Tesseract.js识别图像文本的基本步骤。您可以根据需要自定义这些代码以满足您的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Q shen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值