Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/36.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Node.js 处理从Node js到Angular 2的错误的正确方法是什么?_Node.js_Angular - Fatal编程技术网

Node.js 处理从Node js到Angular 2的错误的正确方法是什么?

Node.js 处理从Node js到Angular 2的错误的正确方法是什么?,node.js,angular,Node.js,Angular,我有一个简单的任务。比方说,该用户可以以包含两个字段(标题和内容)的形式添加新闻。标题字段必须填写。我可以在客户端检查,也可以在服务器端检查,例如: 新闻网 var _this = module.exports = { add: (news) => { return new Promise((resolve, reject) => { if(!news.title) reject('Title must be

我有一个简单的任务。比方说,该用户可以以包含两个字段(标题和内容)的形式添加新闻。标题字段必须填写。我可以在客户端检查,也可以在服务器端检查,例如:

新闻网

var _this = module.exports = {
   add: (news) => {
      return new Promise((resolve, reject) => {
            if(!news.title)
                reject('Title must be filled!')
            //rest of code
      })
   }
}
if (!news.title) {
    reject({statusCode: 404, errorCode: 'MISSING_TITLE'});
}
此错误可以在main app.js中捕获

app.post('/add_news', (req, resp) => {
   var news = req.body.data;

   _news.add(news).then(result => {
       //send success
   }).catch(err => {
       //send error
   })
})
我想在客户端了解一下:

this.newsService.add(news).subscribe(
   result => {
      //here ok
   }, 
   error => {
     //here errors
   })
this.newsService.add(news).subscribe(
    result => {
        //here ok
    }, 
    error => {
        if (error === 'MISSING_TITLE') {
            alert('Title field is required!'); // or modify the $scope to show some error message in your template
        } else {
            alert('An error occurred'); // fallback to general error message when some other message comes
        }
    })
怎么做?我应该在服务器端向客户端发送什么?resp.status无法按我的要求工作。这可能是更好的解决方案吗


关于

一般来说,您的API应该返回一些错误代码(数字或字符串,这无关紧要),并且您的角度前端应该处理该错误代码

新闻网

var _this = module.exports = {
   add: (news) => {
      return new Promise((resolve, reject) => {
            if(!news.title)
                reject('Title must be filled!')
            //rest of code
      })
   }
}
if (!news.title) {
    reject({statusCode: 404, errorCode: 'MISSING_TITLE'});
}
app.js

_news.add(news).then(result => {
    //send success
}).catch(err => {
    // process only errors with `statusCode` and `errorCode`
    if (err.statusCode && err.errorCode) {
        resp.status(err.statusCode);
        resp.json(err.errorCode);
    } else { // otherwise return generic error
        resp.status(500);
        resp.json('API_ERROR');
    }
})
然后在客户端:

this.newsService.add(news).subscribe(
   result => {
      //here ok
   }, 
   error => {
     //here errors
   })
this.newsService.add(news).subscribe(
    result => {
        //here ok
    }, 
    error => {
        if (error === 'MISSING_TITLE') {
            alert('Title field is required!'); // or modify the $scope to show some error message in your template
        } else {
            alert('An error occurred'); // fallback to general error message when some other message comes
        }
    })