公正な警告私はノードにかなり慣れていないため、正しい質問をしていない可能性があります
Web サイトでブログを作成しようとしていますが、投稿の表示ルートに、長い ID ではなく投稿タイトルのスラッグ バージョンを含めたいと考えています。例は、example.com/17489349823789423832 ではなく、example.com/blog-title-here です。slugify をインストールしましたが、動作しないようです。タイトルをスラッグとして保存するのに問題があり、ガイダンスがあれば大歓迎です。
//SHOW BLOG ROUTE
app.get("/blogs/:slug", function(req, res){
var slug = slugify(req.body.blog.title);
Blog.find({ slug: req.params.slug}, function (err, foundBlog) {
if(err){
res.redirect("/blogs");
} else {
res.render("show", {blog: foundBlog});
}
})
});
これは、私が正しいとは思わない href を持つ [投稿の表示] ボタンを含むブログのインデックス ページです。
<div class="blog-feed">
<div class="container">
<div class="row">
<% blogs.forEach(function(blog){ %>
<div class="col-lg-4 mb-4">
<div class="card">
<img class="card-img-top" src="<%= blog.image %>" alt="Card image cap">
<div class="card-body text-center">
<h5 class="card-title"><%= blog.title %></h5>
<p class="card-text"><%- blog.body %></p>
<a href="/blogs/<%= blog.slug %>" class="btn btn-primary">View Post</a>
</div>
</div>
</div>
<% }) %>
</div>
</div>
</div>
投稿をデータベースに保存する方法は次のとおりです
//CREATE BLOG ROUTE
app.post("/blogs", function(req, res){
//create blog
console.log(req.body);
req.body.blog.body = req.sanitize(req.body.blog.body)
console.log("===========");
console.log(req.body);
console.log(slugify(req.body.blog.title));
Blog.create(req.body.blog, function(err, newBlog){
if(err){
res.render("blogNew");
} else {
//then, redirect to the index
res.redirect("/blogs");
}
})
});
事前に助けてくれてありがとう!