我有一个 React 组件:
import React from 'react';
import UserPhoto from '../../images/Dorothy.jpg';
import { useState } from 'react';
import PostVideoIcon from '../icons/post/PostVideoIcon';
import PostImageIcon from '../icons/post/PostImageIcon';
import PostPhotoIcon from '../icons/post/PostPhotoIcon';
import PostLinkIcon from '../icons/post/PostLinkIcon';
import PostIconWrapper from '../PostIconWrapper/PostIconWrapper';
const NewsAddPost = () => {
const placeholder = 'What’s on your mind, Dorothy?';
const [text, setText] = useState(placeholder);
const [isFocused, setIsFocused] = useState(false);
const handleSendClick = async () => {
const formData = new FormData();
const date = new Date().toISOString();
const author = 'Dorothy Kovalsky Parker'; // ! temporary hardcode
const content = document.querySelector("#content").textContent;
console.log(date + ' ' + author + ' ' + content);
formData.append("date", date);
formData.append("author", author);
formData.append("content", content);
try {
fetch('http://localhost:5000/posts', {
method: 'POST',
body: formData,
});
} catch (error) {
console.log(error);
}
};
return (
<div className='flex flex-col gap-[15px] p-[15px] bg-[#fff] rounded-[15px] shadow-componentshadow'>
<div className='flex gap-[10px] items-center'>
<div style={{ backgroundImage: `url(${UserPhoto})` }}
className='h-[40px] w-[40px] rounded-full relative bg-center bg-cover bg-no-repeat' ></div>
<div contentEditable="true"
name='content'
id='content'
placeholder={text ? text : placeholder}
onFocus={() => setIsFocused(true)}
onBlur={() => { setIsFocused(false); setText(text.trim() ? text.trim() : placeholder) }}
suppressContentEditableWarning={true}
onInput={e => setText(e.currentTarget.innerText)}
className='bg-colorExtraLightGray w-[100%] rounded-[10px] p-[8px] text-colorTextLightGray resize-none hover:bg-colorLightGray hover:cursor-pointer focus:hover:bg-white focus:bg-white focus:cursor-auto focus:outline-colorExtraLightGray focus:text-colorTextBlack'>
</div>
</div>
{(text.trim() !== placeholder || isFocused) ?
<div className='flex gap-[10px] items-center justify-between'>
<div className='flex items-center gap-[10px]'>
<PostIconWrapper><PostVideoIcon /></PostIconWrapper>
<PostIconWrapper><PostImageIcon /></PostIconWrapper>
<PostIconWrapper><PostPhotoIcon /></PostIconWrapper>
<PostIconWrapper><PostLinkIcon /></PostIconWrapper>
</div>
<button className="bg-accent py-[12px] border border-accent px-[15px] rounded-[10px] text-[#fff] gap-[10px] whitespace-nowrap hover:bg-opacity-90"
onClick={handleSendClick}>
Publish
</button>
</div>
: <></>
}
</div>
);
};
export default NewsAddPost;
console.log(date + ' ' + author + ' ' + content);
返回:“2024-02-29T14:18:31.178Z Dorothy Kovalsky Parker fsd fs sdf sdff” - 所有字段值都可以。
在后端控制台我看到以下错误:
错误:验证失败:内容:路径
为必填项。,日期:路径content
为必填项。,作者:路径date
为必填项。所有字段值:未定义。author
我错过了什么? 谢谢
你可以这样做:
const data = {
date,
author,
content,
}
fetch('http://localhost:5000/posts', {
method: 'POST',
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(data),
});
这里
Content-Type
很重要,如果你的应用程序接受json,那么上面的代码是有效的。
您可以参考mdn文档这里