如何将 mongodb 数据库的内容显示到前端? [关闭]

Posted

技术标签:

【中文标题】如何将 mongodb 数据库的内容显示到前端? [关闭]【英文标题】:How do I display contents of my mongodb database to my front end? [closed] 【发布时间】:2019-05-21 14:21:06 【问题描述】:

基本上我需要从我的 html 中检索用户输入。使用该输入通过 mongoose 搜索我的 mongoDB 数据库。然后检索该信息并将其显示到前端。我不知道该怎么做。

【问题讨论】:

欢迎堆栈溢出。有很多这样的博客 - medium.com/netscape/…。一旦遇到特定问题,请仔细阅读它们并返回到 ***。 【参考方案1】:

这是一个更大的问题。让我帮你指出一些细节。

    使用 mongoose 连接器定义 mongo 模型。 在 nodejs 代码中创建 get 路由以处理来自客户端的调用。 使用 fetch 或任何客户端 http 包装器调用您的节点服务器。 各自的模型或服务编写模型。查找并返回响应。

【讨论】:

【参考方案2】:

检索数据意味着向您的节点端点发送 Get Request

由于我使用的是 axios,所以我建议你也使用 axios(如果你使用的是 react 或任何其他框架,请 npm install axios)或者你可以简单地复制它的脚本 CDN

您可以从前端简单地

axios.get("Your url address" + "api route address").then((response) => 
         //do whatever with your response
        ).catch(error => 
         //Do something in case of error 
       )

以实际地址为例,假设我有一个节点服务器连接到在 localhost 8000 上运行的 mongoose,我的 api 端点看起来像这样(Backend

我已经像这样导入了我的用户架构

const User = require("./../models/userSchema.js")
const User = require("./../models/userSchema.js")

router.get("/",  async (req, res) => 
  const contactList  = await User.find() //coming from mongoose 
  res.send(contactList)
)

通过axios,我的api请求会是这样的(frontend

axios.get("http://localhost:8000/").then((response) => 

后端部分 -> 发布请求

首先像这样定义和导出一个mongoose Schema

const mongoose = require('mongoose')

const userSchema = new mongoose.Schema(
    firstName: String,
    lastName: String,
    address: String, 
    email: 
        type: String,
        default: "www.xyz@abc.com"
    ,
    number: Number,
    OTP: Number,
    createdAt: type: Date, default: Date.now,
    DateOfBirth: 
        type: String,
        default: "1/01/2001"
    ,
    image: 
        type: String,
        default: "http://icons.iconarchive.com/icons/graphicloads/100-flat/256/contact-icon.png"
    , 

)


module.exports = mongoose.model("User", userSchema)

然后,希望您已经使用 MVC 模式配置了节点,将其导入到您需要使用模式的路由中

const express = require("express")
const router = express.Router() 
const User = require("./../models/userSchema.js")

在该架构中创建一个接受发布请求(或放置请求)的 API 路由或端点

  router.post("/message", async (req, res) => 
  const newMessage = new User(
     firstName: req.body.(whatever from your request contains firstName
    .....
    ......
    )
  )

一旦你填写了你得到的数据(req.body 包含数据)你需要保存它,在上面的路线上扩展

 router.post("/message", async (req, res) => 
  const newMessage = new User(
     firstName: req.body.(whatever from your request contains firstName
    .....
    ......
    )
newMessage.save().then((response) => 
if (error) 
      console.log(error)
      throw  new Error (error)
       else 
        console.dir(responseData)
        res.send(responseData)
      
  )
  )

前端部分

由于我使用的是 axios,所以我建议你也使用 axios(如果你使用的是 react 或任何其他框架,则 npm install axios)或者你可以简单地复制它的脚本 CDN

在 axios 内部,我们发送 post 请求

 axios.post("Your port address" + Message , object).then(response =>    
          console.log(response)
          ).catch(error => 
            console.log(error)  
          )

【讨论】:

以上是关于如何将 mongodb 数据库的内容显示到前端? [关闭]的主要内容,如果未能解决你的问题,请参考以下文章

如何将 html 数据从节点 js 发送到前端?

MERN 堆栈和 Socket 到 Mongodb - 从数据库到前端的实时数据

如何使用 React 前端从 Mongoose 显示带有 <img> 的图像

如何使用 flask_pymongo 将数据从 mongodb 显示到烧瓶模板?

从 MongoDB 在 Angular.js 中显示图像

如何通过SpringBoot表单将html内容保存在mongodb中