5

CSS3 がサポートされていない場合、Modernizr と jQuery の組み合わせを使用してトランジションに似たものを有効にする方法はありますか? 私が現在していることは、このようなものです...

<div class="hoverable">
 <p>This div changes both width and height on hover</p>
</div>

CSSは

.hoverable {
 height: 100px;
 width: 2000px;
 transition: height .5s, width .5s;
}

.hoverable:hover {
 height: 200px;
 width: 100px;
}

CSS3トランジションがサポートされていない場合、現在Modernizrを使用して、divをデフォルトでホバー状態にしています。CSS3 がサポートされていない場合、Modernizr を使用して jQuery アニメーションをトリガーする方法はありますか? jQuery を使用しない場合は、カスタム アニメーションも使用できますが、その方法もよくわかりません。

4

2 に答える 2

12

これを自分で解決しました。私がやった方法はこのようなものでした

<!doctype html>
<html>
    <head>
        <title>Modernizr + jQuery Testing</title>
        <script type="text/javascript" src="modernizr.js"></script>
        <script type="text/javascript" src="jquery.js"></script>
        <script type="text/javascript">
        if(!Modernizr.csstransitions) { // Test if CSS transitions are supported
            $(function() {
                $('#js').hover(function(){
                    $(this).animate({width:'50px',height:'50px'},{queue:false,duration:500});
                }, function(){
                    $(this).animate({width:'100px',height:'100px'},{queue:false,duration:500});
                });
            });
        }
        </script>
        <style type="text/css">
            body {
                margin: 0;
                padding: 0;
            }
            div {
                border: 1px solid red;
                height: 100px;
                margin: 25px auto;
                width: 100px;
            }
            #css {
                transition: height .5s, width .5s;
                -khtml-transition: height .5s, width .5s;
                -moz-transition: height .5s, width .5s;
                -o-transition: height .5s, width .5s;
                -webkit-transition: height .5s, width .5s;
            }
            #css:hover {
                height: 50px;
                width: 50px;
            }
        </style>
    </head>

    <body>
        <div id="js">
            JS
        </div>
        <div id="css">
            CSS
        </div>
    </body>
</html>

それは完璧に機能しました。CSS は新しいブラウザーでのみアニメーション化され (それが可能な唯一の場所であるため)、JS は古いブラウザーでのみアニメーション化されます。このスクリプトを使用すると、http://www.modernizr.com/ から modernizr を、http: //www.jquery.com/ から jQuery を取得できます(もちろん)。

于 2011-05-24T17:03:20.737 に答える
4

以下を使用できます。

if(!Modernizr.csstransitions) { // CSS トランジションがサポートされているかどうかをテストします
    $('#myDiv').bind({
        マウス入力: 関数() {
            $(this).animate({
                幅: 1000,
                高さ: 1000
            }、1000);
        }、
        mouseleave: 関数() {
            $(this).animate({
                幅: 100,
                高さ: 100
            }、1000);
        }
    });
}
于 2011-05-23T15:03:35.077 に答える