我正在嘗試創建一個基本的 nodejs API(無框架)
我的檔案夾結構是
controllers
productController.js
models
productModels.js
data
products.js
node_modules
package.json
package-lock.json
server.js
我正在嘗試將產品資料發送給與特定產品 ID 關聯的客戶端。但我在這里面臨的問題是在 productModel.js 檔案中。在該檔案中,我無法使用 ID 過濾掉特定產品。一旦我在 array.prototype.find() 方法中使用 id 作為條件,它似乎無法識別 id 的值。我想知道為什么?
products.js 檔案
export const products = [
{
"userId": 1,
"id": 1,
"title": "sunt aut facere repellat provident occaecati excepturi optio reprehenderit",
"body": "quia et suscipit\nsuscipit recusandae consequuntur expedita et cum\nreprehenderit molestiae ut ut quas totam\nnostrum rerum est autem sunt rem eveniet architecto"
},
{
"userId": 1,
"id": 2,
"title": "qui est esse",
"body": "est rerum tempore vitae\nsequi sint nihil reprehenderit dolor beatae ea dolores neque\nfugiat blanditiis voluptate porro vel nihil molestiae ut reiciendis\nqui aperiam non debitis possimus qui neque nisi nulla"
},
{
"userId": 1,
"id": 3,
"title": "ea molestias quasi exercitationem repellat qui ipsa sit aut",
"body": "et iusto sed quo iure\nvoluptatem occaecati omnis eligendi aut ad\nvoluptatem doloribus vel accusantium quis pariatur\nmolestiae porro eius odio et labore et velit aut"
},
{
"userId": 1,
"id": 4,
"title": "eum et est occaecati",
"body": "ullam et saepe reiciendis voluptatem adipisci\nsit amet autem assumenda provident rerum culpa\nquis hic commodi nesciunt rem tenetur doloremque ipsam iure\nquis sunt voluptatem rerum illo velit"
}]
productController.js 檔案
import {findAll, findById} from '../models/productModel.js'
export const getProduct = async (req, res, id) => {
try{
const product = await findById(id)
if(!product){
res.end(JSON.stringify({message: 'Prdouct not found'}))
}else{
res.writeHead(200, { 'Content-Type': 'application/json' });
res.end(JSON.stringify(product));
}
}catch(err){
console.log(err)
}
}
productModel.js 檔案
import {products} from '../data/products.js'
export const findById = (id) => {
const promise = new Promise((resolve, reject) => {
setTimeout(() => {
console.log(id)
const product = products.find(p => p.id === id)
resolve(product)
// reject('SERVER ERROR')
}, 1000)
})
return promise
}
server.js 檔案
import http from 'http'
import { getProducts, getProduct } from './controllers/productControllers.js';
const server = http.createServer((req, res) => {
if(req.url === '/api/products' && req.method === 'GET'){
getProducts(req, res)
}else if(req.url.match(/\/api\/products\/([0-9] )/) && req.method === 'GET'){
const id = req.url.split('/')[3]
getProduct(req, res, id)
}
else{
res.writeHead(200, { 'Content-Type': 'text/html' });
res.end("Not found");
}
});
const port = process.env.PORT || 8000
server.listen(port, () => {console.log(`Server running on port ${8000}`)});
uj5u.com熱心網友回復:
似乎是您將 astring與 a進行比較number。因此"1" === 1 // false。
嘗試id使用parseInt()將路徑從路徑轉換為 ??Int ,然后將其傳遞給您的函式
const id = parseInt(req.url.split('/')[3], 10)
uj5u.com熱心網友回復:
您id從中獲得的req.url.split('/')[3]是 a string,但您模型中number的產品 ID 是s。如果兩個運算元的型別不同,您將與===which進行比較false。因此,您的比較將始終回傳false,您將找不到產品。用
const id = (req.url.split('/')[3])
相反,這將產生id一個數字。
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/337383.html
標籤:节点.js 休息 es6-promise 休息 异步javascript
上一篇:如何在行的底部對齊內容
