当前位置: 首页 > news >正文

Next.js【详解】获取数据(访问接口)

Next.js 中分为 服务端组件 和 客户端组件,内置的获取数据各不相同

服务端组件

方式1 – 使用 fetch

export default async function Page() {
  const data = await fetch('https://api.vercel.app/blog')
  const posts = await data.json()
  return (
    <ul>
      {posts.map((post) => (
        <li key={post.id}>{post.title}</li>
      ))}
    </ul>
  )
}

方式2 – 使用 ORM 或 数据库

以 MongoDB 为例,使用 mongoose 连接

1. 安装 mongoose

pnpm i mongoose 

2. 创建数据库连接文件 src\app\lib\db.js

const mongoose = require("mongoose");

async function connectDB() {
  try {
    // 连接到本地 MongoDB 数据库 -- mongodb://数据库的用户名:密码@数据库的主机名:端口号/数据库的名称
    await mongoose.connect("mongodb://test:password@localhost:27018/test");
    console.log("MongoDB 连接成功");
  } catch (error) {
    console.error("MongoDB 连接报错", error);
    // 退出进程
    process.exit(1);
  }
}

module.exports = connectDB;

3. 创建数据表映射文件 src\app\lib\models\Blog.js

const mongoose = require("mongoose");

const blogSchema = new mongoose.Schema({
  title: String,
  content: String,
});
// 需要有第三个参数,否则对应的数据表名称会是blogs
const Blog = mongoose.model("blog", blogSchema, "blog");

module.exports = Blog;

4. 页面中导入使用

src\app\test\page.tsx

import connectDB from "../lib/db";
import Blog from "../lib/models/Blog";

export default async function HomePage() {
  try {
    // 连接数据库
    let res = await connectDB();

    // 查询博客数据
    const blogList = await Blog.find();

    return (
      <div>
        <h1>博客列表</h1>
        <ul>
          {blogList.map((blog) => (
            <li key={blog._id.toString()}>{blog.title}</li>
          ))}
        </ul>
      </div>
    );
  } catch (error) {
    console.error("获取数据出错:", error);
    return <div>获取数据失败</div>;
  }
}

5. Docker destop 安装 MongoDB

见 https://blog.csdn.net/weixin_41192489/article/details/145176073

6. 使用 MongoDB Compass 连接 MongoDB

下载安装 MongoDB Compass
https://www.mongodb.com/zh-cn/docs/compass/current/

新建连接

在这里插入图片描述
在这里插入图片描述

7. 创建数据库 test , 数据表 blog

在这里插入图片描述
在这里插入图片描述

8. 创建一条测试数据

在这里插入图片描述

{
  "_id": {
    "$oid": "67aefdd5de9bca5aae5aa6f8"
  },
  "title": "第1篇博客的标题",
  "content": "第1篇博客的内容"
}

在这里插入图片描述
在这里插入图片描述

9. 为数据库 test 创建用户名、密码和角色

在这里插入图片描述
在这里插入图片描述

db.createUser( { user: "test", pwd: "password", roles: [ { role: "dbOwner", db: "test" } ] } )
  • user:指定要创建的用户名。
  • pwd:指定该用户的密码。
  • roles:指定用户的角色,角色决定了用户对数据库的操作权限。可以指定多个角色,每个角色是一个包含 role 和 db 的对象。role 是角色名称,db 是角色生效的数据库。

常见的角色及其说明:

  • read:允许用户读取指定数据库中的数据。
  • readWrite:允许用户读写指定数据库中的数据。
  • dbAdmin:允许用户管理指定数据库,如创建索引、查看统计信息等。
  • userAdmin:允许用户管理指定数据库中的用户和角色。
  • dbOwner:拥有指定数据库的所有权限,包括读写、管理用户和角色等。
  • root:拥有所有数据库的最高权限。

10. 启动项目,测试效果

浏览器访问 http://localhost:3000/test,效果如下:

在这里插入图片描述

客户端组件

见官网 https://nextjs.org/docs/app/getting-started/fetching-data#client-components


文章转载自:

http://gdxlc5CW.hrydL.cn
http://SkMK5VgK.hrydL.cn
http://OHBLrAWd.hrydL.cn
http://Yvev0ZlK.hrydL.cn
http://WdzsaHgS.hrydL.cn
http://CKgIwPXz.hrydL.cn
http://E2R14VkR.hrydL.cn
http://wkTklVJG.hrydL.cn
http://9CSqk8Oq.hrydL.cn
http://OISrrJZt.hrydL.cn
http://LUJU56fx.hrydL.cn
http://h5VvJTfz.hrydL.cn
http://0GYWGIVR.hrydL.cn
http://v6XNqnm1.hrydL.cn
http://EdfUKCtY.hrydL.cn
http://RxnQ6U1N.hrydL.cn
http://5TApg69t.hrydL.cn
http://mGFLcTFt.hrydL.cn
http://umtoaBDU.hrydL.cn
http://oIKU3HDl.hrydL.cn
http://BC22OO8k.hrydL.cn
http://jT8Wwmrn.hrydL.cn
http://qx5pW0Sa.hrydL.cn
http://OqpxY1eZ.hrydL.cn
http://i41bNWBt.hrydL.cn
http://wW5RJaDy.hrydL.cn
http://7Dizn412.hrydL.cn
http://UQTZ3UEI.hrydL.cn
http://4yORBDZ1.hrydL.cn
http://clwQ3Odn.hrydL.cn
http://www.dtcms.com/a/15185.html

相关文章:

  • 什么是高亮环形光源
  • Vue2/Vue3分别如何使用computed
  • 深入理解Java三大特性:封装、继承和多态
  • python中的深度学习框架TensorFlow 和 PyTorch 有什么区别?
  • 调用DeepSeek API接口:实现智能数据挖掘与分析
  • 记录阿里云CDN配置
  • C语言如何实现面向对象?——从结构体到自由函数的思考
  • 分享一些处理复杂HTML结构的经验
  • 网络安全学习笔记
  • java处理pgsql的text[]类型数据问题
  • window patch按块分割矩阵
  • 大脑网络与智力:基于图神经网络的静息态fMRI数据分析方法|文献速递-医学影像人工智能进展
  • HashMap详解+简单手写实现(哈希表)
  • 深度学习机器学习:常用激活函数(activation function)详解
  • Qt Creator 5.0.2 (Community)用久了突然变得很卡
  • Kafka分区管理大师指南:扩容、均衡、迁移与限流全解析
  • Flutter 实现 iOS 小组件与主 App 的通信
  • make命令学习
  • 知识拓展:设计模式之装饰器模式
  • 传输层协议TCP ( 下 )
  • springboot集成zookeeper的增删改查、节点监听、分布式读写锁、分布式计数器
  • UEFI PI PEI(3. PEI Foundation/PEI Dispatcher)
  • 蓝桥与力扣刷题(108 将有序数组转换成二叉搜索树)
  • 解锁豆瓣高清海报(三)从深度爬虫到URL构造,实现极速下载
  • 网站地址栏怎么变成HTTPS开头?
  • windows平台上 oracle简单操作手册
  • 【SQL server】存储过程模板
  • List对象进行排序
  • 如何提升谷歌SEO排名?
  • Springboot RabbitMQ 消费失败消息清洗与重试机制