我有一个尺寸和位置未知的画布。我想根据画布在量角器中的尺寸和位置来模拟单击到特定坐标上。
以下工作,但很乏味:
var canvas = element(by.id("canvas"));
canvas.getCssValue("left").then(function (left) {
canvas.getCssValue("top").then(function (top) {
canvas.getCssValue("width").then(function(oldWidth) {
canvas.getCssValue("height").then(function (oldHeight) {
// some code that uses left, top, oldWidth and oldHeight together
})
})
})
}
)
})
})
有没有更优雅的方式可以同时使用所有这些承诺?我真的很想做以下事情:
var width = canvas.getCssValue("width");
var height = canvas.getCssValue("height");
var left = canvas.getCssValue("left");
var top = canvas.getCssValue("top");
//code that uses these variables.
但是,当然如果违反诺言的性质。谢谢你的帮助。
function spreader(fn) {
return function(arr) {
return fn.apply(this, arr);
}
}
var width = canvas.getCssValue("width");
var height = canvas.getCssValue("height");
var left = canvas.getCssValue("left");
var top = canvas.getCssValue("top");
protractor.promise.all(width, height, left, top)
.then(spreader(function(width, height, left, top) {
// Use width, height, left, top as values
}));
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句