相关疑难解决方法(0)

Angular HttpPromise:`success` /`error`方法和`then`参数之间的区别

根据AngularJS doc,调用$http返回以下内容:

使用标准then方法和两个http特定方法返回promise对象:successerror.所述然后方法有两个参数一成功以及错误回调将与响应对象被调用.的成功错误的方法采取一个参数-一当请求成功或失败分别将被调用的函数.传递给这些函数的参数是传递给then方法的响应对象的析构表示.

除了response在一种情况下对象被解构的事实之外,我没有区别

  • 传递的成功/错误回调作为参数传递 promise.then
  • 回调作为promise 的promise.success/ promise.error方法的参数传递

有没有?这两种不同方式通过看似相同的回调有什么意义?

promise angularjs

177
推荐指数
5
解决办法
11万
查看次数

如何使用$ resource填充Angular UI Bootstrap typeahead

我试图让Angular UI bootstraps typeahead使用我设置的REST资源.但我不确定如何使用它的异步特性.

目前我已经调整了Angular UI Bootstrap给出的示例.

所以我的html看起来像这样,调用getLibs()来获取typeahead下拉列表.

<div class='container-fluid' ng-controller="TypeaheadCtrl">
    <pre>Model: {{selected| json}}</pre>
    <input type="text"  typeahead="lib.name for lib in getLibs($viewValue)" active='active' ng-model="selected" typeahead-min-length='3' >
</div>
Run Code Online (Sandbox Code Playgroud)

我的资源看起来像这样:

angular.module('LibraryLookupService', ['ngResource']).factory('Library', 
    function($resource){
        return $resource(   "../../api/seq/library/?name__icontains=:searchStr" , {} , 
        {   'get':    {method:'GET'},
            'query':  {method:'GET', params: {} ,  isArray:false },
        }
    )
}
Run Code Online (Sandbox Code Playgroud)

);

我的控制器看起来像这样(我猜它在这里我做的事情不正确):

function TypeaheadCtrl($scope , Library){

    $scope.selected = undefined;
    $scope.active = undefined ;

    $scope.libs = [{name:'initial'} , {name:"values"}];

    $scope.getLibs = function(viewValue){
        console.log("value:", viewValue);
        if (viewValue.length > 3 ) { 
            var return_vals …
Run Code Online (Sandbox Code Playgroud)

asynchronous twitter-bootstrap angularjs

7
推荐指数
2
解决办法
1万
查看次数

NodeJS/ExpressJS在1个流中发送大量数据的响应

我正在使用本机mongo rest api对应用程序进行原型设计,其中Node返回大约400K的json.我使用以下内容来请求mongo的原生api并返回结果:

http.request(options, function(req)
  {
    req.on('data', function(data)
      {
console.log(data,data.rows);
        response.send( 200, data );
      }
    );
  }
)
.on('error', function(error)
  {
console.log('error\t',error);
    response.send(500, error);
  }
)
.end();
Run Code Online (Sandbox Code Playgroud)

当我http://localhost:8001/api/testdata通过curl点击时,响应是正确的(从console.logcurl接收到的节点控制台输出的内容).但是当我在我的应用程序中通过ajax点击它时,流被...中断,甚至data输出到Node的控制台(终端)是奇数:它有多个EOF,并且Chrome的开发工具中的调用的网络>响应在第一个EOF结束.

另一个奇怪的事情:data看起来像:

{
    "offset": 0,
    "rows": [ … ]
}
Run Code Online (Sandbox Code Playgroud)

但在Node和客户端(角度)都不能引用data.rows(它返回undefined).typeof data回报[object Object].

编辑 curl和angular的请求标头(由Node报告)是:

req.headers: {
  'x-action': '',
  'x-ns': 'test.headends',
  'content-type': 'text/plain;charset=utf-8',
  connection: 'close',
  'content-length': '419585'
}
Run Code Online (Sandbox Code Playgroud)

编辑我直接检查了角度和卷曲中的响应头(而不是来自Node),发现存在分歧(来自curl和angular的相同输出直接而不是来自节点):

access-control-allow-headers: "Origin, X-Requested-With, Content-Type, Accept"
access-control-allow-methods: "OPTIONS,GET,POST,PUT,DELETE"
access-control-allow-origin: "*"
connection: "keep-alive" …
Run Code Online (Sandbox Code Playgroud)

xmlhttprequest mongodb node.js express angularjs

5
推荐指数
1
解决办法
7759
查看次数