如何在 reactjs 中重新加载组件(" <注释 />)?



我在做react项目。当我们单击"发表评论"按钮时,我正试图重新加载一个组件(<Comment />(。我实现了onSubmit函数,如下所示。但它正在重新加载整个窗口。我只想重新加载"组件,而不是整个窗口。有人能帮我解决这个问题吗?我不知道该怎么办,请帮忙。。。。。!

import React, { useEffect, useState } from "react";
import { useParams } from "react-router-dom";
import ImageHelper from "../helper/ImageHelper";
import { getoneBlog, postBlogComment } from "../helper/coreapicalls";
import { useHistory } from "react-router-dom";
import { isAutheticated } from "../../auth/helper/index";
import cogoToast from "cogo-toast";
import "../../styles.css";
import Comment from "./Comment";
import ShareButton from "react-web-share-button";
const Fullblog = (config) => {
const useremail = isAutheticated() && isAutheticated().user.email;
const blogId = useParams();
const id = blogId._Id;
// console.log(id);
const history = useHistory();
const [blog, setBlog] = useState({
title: "",
description: "",
tags: "",
photo: "",
comment: "",
loading: false,
error: "",
createdBlog: "",
getaRedirect: false,
});
const [value, setvalue] = useState({
user: useremail,
content: "",
err: "",
success: false,
});
const [error, seterror] = useState(false);
const [loading, setLoading] = useState(false);
const { user, content, err, success } = value;
const onInputChange = (name) => (event) => {
setvalue({ ...value, err: false, [name]: event.target.value });
};
const onSubmit = (event) => {
event.preventDefault();
setvalue({ ...value, err: false });
postBlogComment(id, { user, content })
.then((data) => {
if (data.error) {
setvalue({ ...value, err: data.error, success: false });
} else {
setvalue({
...value,
user: useremail,
content: "",
err: "",
success: true,
});

}
})
.catch(console.log("Error in sending Comment"));
};
const loadBlog = () => {
getoneBlog(id).then((data) => {
if (data.error) {
seterror(data.error);
} else {
setBlog(data);
// console.log(data);
}
});
setLoading(true);
};
useEffect(() => {
loadBlog();
}, []);
///////////////////////////// Post Submit Event ///////////////////
const successMessage = () => {
return (
<div className="">
<div className="">
<div
className="alert alert-success"
style={{ display: success ? "" : "none" }}
>
Comment Posted..!
</div>
</div>
</div>
);
};
const errorMessage = () => {
return (
<div className="">
<div className="">
<div
className="alert alert-danger"
style={{ display: err ? "" : "none" }}
>
{err}
</div>
</div>
</div>
);
};
return (
<div>
<div className="py-md-5 py-3">
<div className="Fullblog container">
<div>
<h1 className="FullblogTittle">{blog.title}</h1>
<p className="tags text-right">{blog.tags}</p>
{loading ? (
<ImageHelper blog={blog} />
) : (
<div class="spinner-border text-danger" role="status"></div>
)}
<div
className="description"
dangerouslySetInnerHTML={{ __html: blog.description }}
/>
<span>
<ShareButton
buttonStyle={{
color: "#ffca08",
background: "#fff",
padding: "10px 12px",
border: "none",
width: "100%",
}}
/>
</span>
<div className="container Comment_stytum mt-4">
{successMessage()}
{errorMessage()}
<div className="mx-sm-3 mb-2">
<div className="">
<textarea
className="comment_input"
name="content"
value={content}
onChange={onInputChange("content")}
placeholder="Write Comment"
></textarea>
</div>
<input
className="d-none"
name="user"
value={user}
onChange={onInputChange("user")}
/>
<button type="submit" onClick={onSubmit} className="post-btn">
Post Comment
</button>
</div>
</div>
</div>
</div>
</div>
<Comment />
</div>
);
};
export default Fullblog;

你能用这个修改进行测试吗?

<form className="mx-sm-3 mb-2" onSubmot={onSubmit}>
<div className="">
<textarea
className="comment_input"
name="content"
value={content}
onChange={onInputChange("content")}
placeholder="Write Comment"
></textarea>
</div>
<input
className="d-none"
name="user"
value={user}
onChange={onInputChange("user")}
/>
<button type="submit" className="post-btn">
Post Comment
</button>
</form>

因为使用button type='submit'即将提交表单(但没有(,通常使用submit,我们在form上声明该方法。

要重新发布一个组件,你应该更新他的状态或道具,在你的情况下,我建议你试着找到这两个组件之间的关系,就像你把评论数据作为道具发送,在你添加新的评论后,你更新状态,评论组件从状态中获得数据作为道具,所以它会自动重新发布,否则,你可以使用forceUpdate((,但我不建议使用

https://reactjs.org/docs/react-component.html#forceupdate

最新更新