0

/*

最初のブロックを 2 番目のブロックにすることはできますか? 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());
4

2 に答える 2

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();
}
于 2013-10-23T18:35:57.383 に答える
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();
     }
})();
于 2013-10-23T18:25:01.013 に答える