javascript - Protractor - 如何将一组 promise 的结果放入另一个数组

标签 javascript arrays angularjs protractor

我从这段代码中得到了一系列 promise :element.all(by.repeater('unit in units')) ,我发现很难将数据放入另一个数组:

element.all(by.repeater('unit in units')).then(function (arr) {
    var items = [];

    for (var i = 0; i < arr.length; i++) {
      arr[i].getText().then(function(text) {
        items.push(text);
      });
    }

   //PROBLEM ITEMS is Empty
   console.log(items);
});

最佳答案

设法以更简单的方式获得相同的结果,避免使用 Q 和中继器。使用内置 map 可以解决问题。

var tabs = element.all(by.css('.unitTabs li a')).map(function (elm) {
    return elm.getText();
});

tabs.then(function (result) {
    var sorted = _.sortBy(result, function (name) { return name; });
    for (var i = 0; i < result.length; i++) {
        expect(result[i]).toBe(sorted[i]);
    }
});

关于javascript - Protractor - 如何将一组 promise 的结果放入另一个数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21736191/

相关文章:

javascript - 如何将 svg 按钮变成下载按钮?

javascript - 找不到 Discord.js 音乐机器人 ffmpeg?

c++ - 颠倒句子中单词的顺序

C - 两个 for 循环中的数组

angularjs - 使用 AngularJS 动态更改 Bootstrap 3 列宽?

javascript - 刷新 Chrome 时出现问题

javascript - 对包含对象的数组进行切片并获取包含对象副本的数组

javascript - 如何使用angularjs将div附加到一个div中

mysql - 为什么我收到此错误 :? angular.js:13920 错误:[ngRepeat:dupes] 错误( native )

javascript - 在 Ajax 加载的外部 html 中的脚本后调用事件