我编写了以下代码(页面对象模式)。正常工作。
但是,我不喜欢这样,因为我无法从“ pressHelpLink”中删除“ then”。而是将代码添加到getElementByLink中。

我希望看到ElementFinder Promise(而不是ManagedPromise)是getElementByLink(“ Help”)的结果

如何很好地解决硒的承诺?

var self = Page.create({
    url: {value: ''},

    // function:
    getElementByLink: {
        value: function (link) {
            return element.all(by.repeater('items')).then(function (el) {
                var my_array = el.map(function (el) {
                    return el.element(self.by.xpath('a'));
                });
                var element_array_finder = protractor.ElementArrayFinder.fromArray(my_array);

                var element = element_array_finder.filter(function (el) {
                    return el.getText().then(function (text) {
                        return text === link;
                    })
                });
                return element;
            }).then(function (element) {
                world.expect(element.length).equal(1);
                return element[0];
            });
        }

    },

    // elements:
    HelpLink: {
        get: function () {
            return self.getElementByLink('Help');
        }
    },

    // method:

    pressHelpLink: {
        value: function () {
            return self.HelpLink.then(function (el) {
                return el.click()
            });
        }
    },
});

最佳答案

为什么不使用cssContainingText?也许像...

// elements:
HelpLink: {
    get: function () {
        return element(by.cssContainingText('a', 'Help');
    }
},

// method:

pressHelpLink: {
    value: function () {
        return self.HelpLink.click()
    }
},

关于javascript - 如何很好地解决 Selenium 的 promise ? Protractor ,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42165375/

10-12 23:54