我一直在使用要用于多个小部件的翻转效果,但我一直在努力解决以下问题:我为不同的小部件使用了相同的基本 HTML。所以当我想翻转页面上的第一个小部件时,我工作得很好。当我想翻转另一个小部件时,它根本不起作用......
我注意到问题与我的脚本有关。因为我用过document.getElementById
,它只识别第一个唯一ID。但现在我不想在每个不同的小部件中更改 id 的名称。他们是一种重写我的脚本的方法,以便我可以在其中定义多个 id 吗?
HTML
<section class="widget span3">
<!--front-->
<div id="front" class="widget-1-2 flip">
<div class="widget-header">
<h2>Monthly Statistics</h2>
<div class="btn-group pull-right">
<button id="btn-front" class="btn"><i class="icon-cogs icon-white" alt="settings"></i></button>
<button class="btn btn-minimize"><i class="icon-chevron-up icon-white" alt="minimize"></i></button>
<button class="btn btn-close"><i class="icon-remove icon-white" alt="close"></i></button>
</div>
</div>
<div class="widget-content"><p>This is the front.</p></div>
</div><!--/front-->
<!--back-->
<div id="back" class="widget-1-2 flip">
<div class="widget-header">
<h2>Monthly Statistics / Settings</h2>
<div class="btn-group pull-right">
<button id="btn-back" class="btn"><i class="icon-signal icon-white" alt="charts"></i></button>
<button class="btn btn-minimize"><i class="icon-chevron-up icon-white" alt="minimize"></i></button>
<button class="btn btn-close"><i class="icon-remove icon-white" alt="close"></i></button>
</div>
</div>
<div class="widget-content"><p>This is the back.</p></div>
</div><!--/back-->
</section><!--/widget-1-2-->
JavaScript
<script>
document.getElementById( 'btn-front' ).addEventListener( 'click', function( event ) {
event.preventDefault();
document.getElementById( 'back' ).className = 'flip flip-front';
document.getElementById( 'front' ).className = 'flip flip-back';
}, false );
document.getElementById( 'back' ).addEventListener( 'click', function( event ) {
event.preventDefault();
document.getElementById( 'back' ).className = 'flip';
document.getElementById( 'front' ).className = 'flip';
}, false );
</script>
对于旋转/翻转效果,我使用 CSS。预先感谢!