javascript - 這個路由這么寫有什么問題?我想刪掉一條記錄
問題描述
我在roomview.html頁面上想要刪掉一條顯示出來的記錄,roomview.html部分代碼如下:
<h1>房間列表</h1><p> <a href='http://www.intensediesel.com/roomview/addroom'>增加</a></p><table> <thead> <tr><th>_id</th><th>roomName</th><th>roomContent</th><th>roomCreateUser</th><th>roomImg</th><th>roomCreateDate</th><th>roomJoinPeos</th><th>roomChat</th> </tr> </thead> <tbody> <% rooms.forEach(function( room ){ %> <tr><td><%= room._id%></td><td><%= room.roomName %></td><td><%= room.roomContent %></td><td><%= room.roomCreateUser %></td><td><%= room.roomImg %></td><td><%= room.roomCreateDate %></td><td><%= room.roomJoinPeos %></td><td><%= room.roomChat %></td><td><a href='http://www.intensediesel.com/roomview/delete?id=<%=room._id%>'>刪除房間</a> | <a href='http://www.intensediesel.com/roomview/modifyroom?id=<%=room._id%>'>更新房間信息</a></td> </tr> <% }); %> </tbody>
路由roomview.js對應刪除部分代碼如下:
router.get('/delete/:id',function(req,res){ console.log(req.params.id); Room.findById(req.params.id,function(err,doc){if(!doc){ return next(new NotFound('Doc not found'))}else{ doc.remove(function(){res.redirect('/roomview'); })} });});
不過當我點擊刪除房間后頁面卻顯示如下:
Cannot GET /roomview/delete
問題解答
回答1:獲取id
/roomview/delete?id=<%=room._id%>router.get('/delete', cb) req.query.id/roomview/delete/<%=room._id%>router.get('/delete/:id', cb)req.params.id
soonfy
回答2:@soonfy 就是正解。
你在路由里聲明了按照path variable的形式要求參數:/delete/:id,
但在頁面上卻又用了query parameter的形式提供參數: /roomview/delete?id=<%=room._id%>。
那肯定會出錯,最直觀的表現就是你遇到錯誤,即:壓根沒找到路由/roomview/delete對應的處理器,因為你的處理器指定的規則是/delete/:id,而非/delete。
解決方案也簡單,把頁面里改成/roomview/delete/<%=room._id%>,應該就好了
相關文章:
1. 管理員信息修改時的密碼問題2. html5 - 為什么使使用vue cli 腳手架,post-css 沒有自動對css3屬性自動添加瀏覽器前綴呢?3. angular.js - 輸入郵箱地址之后, 如何使其自動在末尾添加分號?4. android - RxJava 中有根據條件執行不同函數的操作符嗎?5. javascript - 如何使用nodejs 將.html 文件轉化成canvas6. java如何生成token?7. javascript - 后臺管理系統左側折疊導航欄數據較多,怎么樣直接通過搜索去定位到具體某一個菜單項位置,并展開當前菜單8. javascript - html5的data屬性怎么指定一個function函數呢?9. 如何解決docker宿主機無法訪問容器中的服務?10. mysql - 電商如何存儲營業額數據
