8

私は純粋なjavascriptを使用してフェードインおよびフェードアウト機能に取り組んでいます。コードは次のとおりです。

(function() {
    var fx = {
        easing: {
            linear: function(progress) {
                return progress;
            },
            quadratic: function(progress) {
                return Math.pow(progress, 2);
            },
            swing: function(progress) {
                return 0.5 - Math.cos(progress * Math.PI) / 2;
            },
            circ: function(progress) {
                return 1 - Math.sin(Math.acos(progress));
            },
            back: function(progress, x) {
                return Math.pow(progress, 2) * ((x + 1) * progress - x);
            },
            bounce: function(progress) {
                for (var a = 0, b = 1, result; 1; a += b, b /= 2) {
                    if (progress >= (7 - 4 * a) / 11) {
                        return -Math.pow((11 - 6 * a - 11 * progress) / 4, 2) + Math.pow(b, 2);
                    }
                }
            },
            elastic: function(progress, x) {
                return Math.pow(2, 10 * (progress - 1)) * Math.cos(20 * Math.PI * x / 3 * progress);
            }
        },
        animate: function(options) {
            var start = new Date;
            var id = setInterval(function() {
                var timePassed = new Date - start;
                var progress = timePassed / options.duration;
                if (progress > 1) {
                    progress = 1;
                }
                options.progress = progress;
                var delta = options.delta(progress);
                options.step(delta);
                if (progress == 1) {
                    clearInterval(id);
                    options.complete();
                }
            }, options.delay || 10);
        },
        fadeOut: function(element, options) {
            var to = 1;
            this.animate({
                duration: options.duration,
                delta: function(progress) {
                    progress = this.progress;
                    return fx.easing.swing(progress);
                },
                complete: options.complete,
                step: function(delta) {
                    element.style.opacity = to - delta;
                }
            });
        },
        fadeIn: function(element, options) {
            var to = 0;
            this.animate({
                duration: options.duration,
                delta: function(progress) {
                    progress = this.progress;
                    return fx.easing.swing(progress);
                },
                complete: options.complete,
                step: function(delta) {
                    element.style.opacity = to + delta;
                }
            });
        }
    };
    window.fx = fx;
})()

次のコードを使用して機能を有効にしています。

document.getElementById('in').addEventListener('click', function() {
    FX.fadeIn(document.getElementById('type'), {
        duration: 2000,
    });
}, false);

しかし、ページをロードすると、アクティベーション コードでエラーが発生します。

私が間違ったことを誰か知っていますか?

どうもありがとう。

4

1 に答える 1

11

いくつかの調整を行うと、コードは正常に動作するはずです...

  1. Richard Daltonが気付いたように、オブジェクトを not で呼び出しfxますFX
  2. オプションが指定されていない場合に備えて、すべてのオプションにデフォルト値を追加します (options.complete未定義のため、サンプル コードはエラーをスローします)。例:

    this.animate({
        duration: options.duration || 1000,
        ...
        complete: options.complete || function() { },
        ...
    });
    
  3. アニメーション化する前にスタイルを調整します (要素がdisplay: noneの代わりに非表示になっていると想像してくださいopacity: 0)... 例 (の場合fadeIn):

    element.style.opacity = 0;
    element.style.visibility = "visible";
    element.style.display = "block";
    
  4. アクションが必要かどうかを確認します (例:fadeIn要素が既に表示されているにもかかわらず を呼び出す):

    isVisible: function(element) {
        return element.style.display !== "none" && 
                element.style.visibility !== "hidden" && 
                element.style.opacity !== "0";
    }
    
    // In fadeIn:
    if (!this.isVisible(element)) {
        ...
    }
    

例を含む修正されたコードは次のとおりです: JSFiddle

確かに、これをもう少し微調整して、いくつかのまれなケースに対処することができます (たとえばfadeIn、要素が現在フェードアウトしているときに への呼び出しがある場合はどうなりますか?)。すべてのブラウザーで機能するとは限りません (古いIE)...しかし、私はあなたを正しい方向に向けたと思います. :)

于 2013-10-27T10:22:13.353 に答える