javascript - 这个路由这么写有什么问题?我想删掉一条记录
问题描述
我在roomview.html页面上想要删掉一条显示出来的记录,roomview.html部分代码如下:
<h1>房间列表</h1><p> <a href='https://www.haobala.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='https://www.haobala.com/roomview/delete?id=<%=room._id%>'>删除房间</a> | <a href='https://www.haobala.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. javascript - vue生成一维码?求助!!!!!急2. ueditor上传服务器提示后端配置项没有正常加载,求助!!!!!3. css - 关于offsetLeft和offsetTop4. python - 关于matplotlib的x轴显示的问题5. angular.js - 怎样在使用ng-repeat属性的标签里面监听单个事件,使其能够单个改变CSS。6. nginx英文文档的WebSocket proxying部分没看太明白,麻烦推荐一点中文文章7. mysql优化 - mysql慢查询copying to tmp table8. css - transform: translateY(-50%)在360浏览器极速模式下使得文字变模糊了9. css - .clearfix:after中为什么设置display: table10. 请教: 关于 python 反斜杠转义的疑问
