目前,我的代码段的工作方式类似于发生错误时,它通过一条消息并在几秒钟后消失,我这样做了$timeout
,即使成功响应,成功消息也会在几秒钟后出现并消失。但由于某些原因,我现在不需要这样。
在这里,您可以查看我当前的摘录:
$http.post('http://127.0.0.1:8000/api/v1/contact/', $scope.formModel)
.then(function(response) {
$scope.successCallBack = 'You have successfully saved your contact';
$scope.formModel = {};
$timeout(function () {
$scope.successCallBack = '';
}, 6000);
}, function(response){
// Showing user exactly what error occurs
var errorData = response.data
$scope.errorCallBack = Object.values(errorData)[0][0];
$timeout(function () {
$scope.errorCallBack = '';
}, 3000);
});
在以上代码段中,如果我不使用,$timeout
则成功和错误将并存。
例如:一个用户提交错误数据并得到错误消息,而在提交正确数据并获得成功消息后,此时屏幕上同时存在成功和错误消息,这很奇怪
我想要类似的内容,当成功消息出现时,它应该存在于屏幕上,如果以后再次出现错误消息,则成功消息应该消失并出现错误消息。
可选的:
在这里,您将了解如何在模板中使用:
<div class="alert alert-success" ng-if="successCallBack">
<p> {{ successCallBack }} </p>
<strong>UserID :</strong>{{ userid }} <br>
<strong> Name :</strong>{{ name }} <br>
<strong> Email :</strong>{{ email }} <br>
<strong> Phone :</strong>{{ phone }} <br>
<a href="#!/crud" class="btn btn-primary">Show Me All Contacts</a>
</div> <!--sucess div ended-->
<div class="alert alert-danger" ng-if="errorCallBack"> <!--( Error div start )this div appear if any error occured during request-->
<p>Oops! You can't save this contact !</p>
<p> Cause, {{ errorCallBack }} </p>
<strong>UserID :</strong>{{ userid }} <br>
<strong> Name :</strong>{{ name }} <br>
<strong> Email :</strong>{{ email }} <br>
<strong> Phone :</strong>{{ phone }} <br>
</div> <!--error div ended-->
希望你能遇到这个问题:
如果我不使用的
$timeout
话,成功和错误将并存。
响应和拒绝处理程序可以调用一个公共函数
$http.post('http://127.0.0.1:8000/api/v1/contact/', $scope.formModel)
.then(function(response) {
displayMessage("success",response);
return response;
}, function(response){
displayMessage("error",response);
throw response;
});
然后将通用代码放入通用函数中:
var timeoutId;
function displayMessage(type,response) {
var success = (type == "success");
$scope.messageClass = success ? "alert-success" : "alert-danger";
var messageDuration = success ? 6000 : 3000;
if (success) {
$scope.messageText = "Contact successfully saved.";
} else if (response.status == 500) {
$scope.messageTest = "Oops, Internal Server Error";
} else {
$scope.messageText = "Oops, YOU DID SOMETHING WRONG!!!!";
};
//cancel previous timeout
timeoutId && $timeout.cancel(timeoutId);
timeoutId = $timeout(function() {
$scope.messageText = "";
}, messageDuration);
}
模板可以简化:
<div class="alert" ng-class="messageClass" ng-show="messageText">
<p> {{ messageText }} </p>
<strong>UserID :</strong>{{ userid }} <br>
<strong> Name :</strong>{{ name }} <br>
<strong> Email :</strong>{{ email }} <br>
<strong> Phone :</strong>{{ phone }} <br>
<a href="#!/crud" class="btn btn-primary">Show Me All Contacts</a>
</div>
问题内容: 我想全局拦截某些错误情况,以防止控制器自己处理错误。我认为我需要HTTP拦截器,但是我不确定如何从我的控制器中处理错误。 我有一个像这样的控制器: 和这样的HTTP拦截器: 这与浏览器重定向到“ /错误”路径一样有效。但在承诺抓的 也 执行了,我不希望这样。 我知道我可以编写代码,使其忽略404错误,但这是无法维护的。假设我进行修改以同时处理500个错误,那么我将不得不再次进行修改(以
问题内容: 使用AngularJS“ http get then”结构(应许)时,如何处理HTTP错误,例如500? 问题是,对于任何非200 HTTP响应,都不会调用内部函数。 问题答案: 您需要添加其他参数:
问题内容: 我有2 ng-包括HTML。考虑服务器中是否不存在ng-include src之一。截至目前,它只会加载空白html,并且在浏览器控制台中会显示未找到http-404文件。 因此,在这种情况下,我只想将默认错误页面(服务器中存在)加载到该特定div中,即一半显示默认错误页面,另一部分显示通过nginclude加载的正确div。 我的逻辑是,使用HTTP拦截器拦截所有HTTP调用。无论何
我正在尝试在javascript中自定义一个可以通过REST调用访问的endpoint。此终结点处理与不同情况相关的多个条件(基本上它生成一次性密码,然后验证它以检查它是否过期等)。 所以基本上结构是这样的: 我在开始时设置了一个对象,然后映射一个json消息,以便检索具有不同代码/消息响应的正文。因此,当终结点输入这些条件时,它将返回对象,并且 Header 始终为 200(调用成功)。像这样:
我正在使用 Log4j2。要求是,如果记录器无法写入日志文件(访问被拒绝、锁定等),则应用程序应关闭。 我编写了以下类来实现这一点: 我用下面的代码以编程方式构建我的文件记录器: 现在我的问题: 我知道在Log4j 1。X.X版本向日志程序添加一个错误处理程序是非常容易的。您可以简单地这样做: 如何在Log4j2版本2.13.3中使用上面的代码执行此操作?
本文向大家介绍详解AngularJS中$http缓存以及处理多个$http请求的方法,包括了详解AngularJS中$http缓存以及处理多个$http请求的方法的使用技巧和注意事项,需要的朋友参考一下 $http 是 AngularJS 中的一个核心服务,用于读取远程服务器的数据。在AngularJS的实际项目中,经常需要处理多个$http请求,每个$http请求返回一个promise,我们可以