我有一个函数.getText,在接下来的页面上,我需要从中返回一个变量num3进行比较。但是最后的断言失败了,因为num3是“ undefined”。

var num3;
...
.getText('my_selector', function(result) {
                const num = (number * result.value) * 0.05;
                const num2 = (number * result.value) - num;
                num3 = Math.round(num2 * 100) / 100;

this.expect.element('my_selector').to.have.value.equal(num3); })
...
.assert.containsText('my_selector2', num3) //undefined

最佳答案

我找到了解决此问题的方法。我们需要.perform函数。 http://nightwatchjs.org/api#perform

var num3;
...
.getText('my_selector', function(result) {
            const num = (number * result.value) * 0.05;
            const num2 = (number * result.value) - num;
            num3 = Math.round(num2 * 100) / 100;

this.expect.element('my_selector').to.have.value.equal(num3); })
...
.perform( function(){
          this.api
              .useXpath()//it's necessary if you use Xpath selector
              .assert.containsText('my_selector2', num3)
            })


有关为何需要这样做的更多信息,请阅读Nightwatch command queue

10-07 17:59