我有一个返回值的函数:
checkValue = function(Name){
var tempIndex=-1;
var nameIndex=0;
return selectElement.all(by.tagName('option')).each(function (element) {
return element.getText().then(function(text){
tempIndex++;
if(text.toString().indexOf(Name)!=-1){
nameIndex=tempIndex;
return nameIndex;
}else{
return nameIndex;
};
});
});
在另一个函数中调用它:
checkValue(Name).then(function(value){
logger.info("value ::"+value);
});
当我调用上面的函数时,该值显示为undefined,并在日志中显示它,然后调用checkValue
。
有什么建议吗?
答案 0 :(得分:0)
您收到undefined
,因为这是each()
返回的内容(不返回任何内容),implementation:
ElementArrayFinder.prototype.each = function(fn) {
return this.map(fn).then(function() {
return null;
});
};
让我们用map()
:
return selectElement.all(by.tagName('option')).map(function (option, index) {
return {
'text': option.getText(),
'index': index
};
}).then(function (options) {
for (var i = 0; i < options.length; i++) {
if (options[i].text === Name)
{
return options[i].index;
}
}
});
我仍然不确定问题的动机方面,为什么你需要选择中的选项索引。无论如何,在处理select->option
构造时,您可能会考虑切换到这一点: