console.log("mongoDB断开连接");
});
②、对来自前端的get请求进行响应:查询数据库mall集合并将结果放在result.list中,再加上status、msg,以json形式返回res。
router.get('/',(req,res,next)=>{
//利用goods模板调用mongooseAPI进行数据库查询
goods.find({},(err,doc)=>{ //查询的回调函数
"use strict";
if (err){
res.json({
status:1,
msg:err.message
})
}else {
res.json({//利用res将数据返回给get请求
status:0,
msg:'',
result:{
count:doc.length,
list:doc
}
})
}
})
});最后记得暴露路由router
module.exports = router;注:接收请求中的参数一般有三种方式,
req.query多用于get请求发送来的数据,参数以?加在请求路径的尾部,用req.query.keyname可以获取到其中的数据。
req.body用于接收post请求,post请求将数据放在request正文中,因此req.body.keyname可以得到其请求数据。
req.params的参数包含在路径当中,例如请求路径为http://localhost:3000/test/myparam,在服务端读取其中的参数;
router.get('/testparams/:param', function (req, res) {
console.log('参数为: ' + req.params.param); //控制台输出路径中的参数:myparam
})3、跨域请求数据
由于本地Vue运行在localhost:8080,而Node在localhost:3000,若要在vue中利用axios实现数据请求,则需要执行跨域代理操作。在vue中的config/index.js文件的dev中配置一个转发代理,当请求”/goods”时,转发到localhost:3000下的/goods:

Node服务器对get请求的解析过程:当请求到达localhost:3000端时,Node服务器的app.js文件对请求路径进行解析,通过app.use()将/goods定位到routes/goods.js文件,在该文件中查询数据库的操作并返回结果:
var goods=require('./routes/goods'); //包含文件routes/goods.js
app.use('/goods',goods); //将访问路径定位到文件4、vue进行数据请求并渲染到页面
在views/GoodsList.vue文件中利用axios对数据进行请求,定义getGoodsList()方法并在挂载后调用:
mounted:function (){
this.getGoodsList();
},
methods:{
getGoodsList(){
axios.get("/goods").then(response =>{
let res=response.data;
if(res.status==0){
this.goodsList=res.result.list;









