问题是,当我按下提交按钮时,它会将数据发送到MongoDB,但我也会收到一个500错误。另一个问题是,当我尝试输入用户数据(在html内部)时,它会发送null。有人能帮助我吗?
这是从.tsx
'use client'
import React, {ChangeEvent, FormEvent, useState} from "react";
import axios from 'axios';
const Form : React.FC = () => {
const [rangeValue, setRangeValue] = React.useState<number | string>("50");
const [name, setName] = useState('');
const giveRangeValue = (event: React.ChangeEvent<HTMLInputElement>) => {
const newRangeValue: string = event.target.value;
setRangeValue(newRangeValue === "0" ? 0 : newRangeValue);
}
const handleSubmit = async (e: FormEvent<HTMLFormElement>)=> {
e.preventDefault()
console.log("Name:", name);
console.log("Range Value:", rangeValue);
const postData = {
gebruikersNaam: name,
risicoScore: rangeValue,
};
try {
const response = await axios.post('/api/risk', postData);
if (response.status === 200) {
console.log(response.data);
} else {
console.error("Error:", response.data);
}
} catch (error){
console.error(error)
}
}
return (
<main className={"flex flex-row"}>
<form onSubmit={handleSubmit}>
<div className={"form-div space-y-4"}>
<div className={"alert flex flex-col items-start"}>
<label>
Naam
</label>
<input
className={'input'}
id="email"
value={name}
type="text"
name="gebruikersNaam"
onChange={(e) =>
setName(e.target.value)}/>
</div>
<div className="alert flex flex-row">
<input
id="range"
type={"range"}
min={0} max={100}
value={rangeValue}
onChange={giveRangeValue}>
</input>
<span className={"value"}>{rangeValue}</span>
</div>
<div className={"form-btns"}>
<button className={"btn mr-5"} type={"submit"}>Maak melding</button>
<button className={"btn btn-form ml-10"} type={"button"}><a href={"../"}>Terug</a>
</button>
</div>
</div>
</form>
</main>
)
}
export default Form
字符串
这就是app/API/risk
import {getCollection} from "@util/mongodb";
import {Riskscore} from "@/types/db/Riskscore";
import {NextApiRequest, NextApiResponse} from "next";
export async function POST(req: NextApiRequest, res: NextApiResponse) {
if (req.method === 'POST') {
try {
const {gebruikersNaam, risicoScore} = req.body;
const collection = await getCollection<Riskscore>('netherlands', 'risicoscores');
const result = await collection.insertOne({
overlast: "E38",
gebruikersNaam: "Jack",
risicoScore: 4,
});
if (result.insertedId) {
res.status(200).json({message: 'Name submitted to MongoDB'});
} else {
res.status(500).json({error: 'Error inserting data into MongoDB'});
}
} catch (error) {
res.status(500).json({error: 'Error submitting name to MongoDB'});
}
} else {
res.status(405).end();
}
}
型
这是Riskscore.d.ts
import {Document} from "mongodb";
export interface Riskscore extends Document {
overlast: string
gebruikersNaam: string
risicoScore: number
}
型
1条答案
按热度按时间kx7yvsdv1#
您的问题出在API响应中。
NextJS 13处理响应的方式与12不同,所以你需要调整你的代码。
字符串