/ *
是否可以将第一个块转换为第二个块?我已经使用requestAnimationFrame完成了类似的操作,但是因为它似乎在这里不起作用。
* /
////////////////////////////////////////////////////////////////////////////////////////
window.performance = window.performance || {};
window.performance.now = (function()
{
return window.performance.now ||
window.performance.webkitNow ||
window.performance.msNow ||
window.performance.mozNow ||
window.performance.oNow || function() { return new Date().getTime(); };
})();
var PeRfOrMaNcE = window.performance;
console.log(PeRfOrMaNcE.now());
////////////////////////////////////////////////////////////////////////////////////////
var PeRfOrMaNcE = (function()
{
return window.performance.now ||
window.performance.webkitNow ||
window.performance.msNow ||
window.performance.mozNow ||
window.performance.oNow || function() { return new Date().getTime(); };
})();
console.log(PeRfOrMaNcE());
答案 0 :(得分:1)
至少在Chrome中,now()
功能需要this === window.performance
。
因此,您必须使用.call
或。bind
来正确调用它。
这似乎有效,尽管它仍然需要window.performance
存在,即使它只是在您第一次尝试代码时初始化为空对象:
var PeRfOrMaNcE = (function()
{
return window.performance.now ||
window.performance.webkitNow ||
window.performance.msNow ||
window.performance.mozNow ||
window.performance.oNow || function() { return new Date().getTime(); };
})().bind(window.performance);
或者,当.bind
不存在时,避免window.performance
来电:
var PeRfOrMaNcE = (function()
{
var wp = window.performance;
var now = wp && (wp.now || wp.webkitNow || wp.msNow || wp.mozNow || wp.oNow);
return now && now.bind(wp) || function() {
return new Date().getTime();
}
})();
答案 1 :(得分:1)
固定。
简洁,但略微混淆。
var PeRfOrMaNcE = function()
{
var wp = window.performance;
var v = ['now', 'webkitNow','msNow','mozNow', 'oNow'];
for (var i in v) {
if (wp[v[i]]) return wp[v[i]]()
}
return (new Date()).getTime();
}