2

我正在尝试在 jQuery 中构建一个基本的滑块。我有 5 个主要部分显示在页面上,当您将鼠标悬停在它们的容器 div 上时,箭头会在第一个和最后一个元素上弹出。

我的下一步是编写代码,将 div(取决于单击侧的左侧或右侧)存储在一个数组中,并将其从 DOM 中删除。但是,我在绑定点击事件时遇到了麻烦。

这是我的CSS:

.left_arrow_background {
 height: 175px;
width: 65px;
/* background:url(../images/left-arrow.png) no-repeat; */
background:#ccc;
opacity: .9;
position: absolute;
cursor: pointer;
z-index: 2;
}

.right_arrow_background {
height: 175px;
width: 65px;
/* background:url(../images/right-arrow.png) no-repeat;*/
background:#ccc;
z-index: 2;
opacity: .9;
position: relative;
left:890px;
cursor: pointer;
}
.boomers_scroller {
height:275px;
padding-left:1px;
display:block;
border-bottom-width: 1px;
border-bottom-style: solid;
border-bottom-color: #CCC;
    overflow:hidden;
}
.all-boomers {
display: block;
float: left;
height: 225px;
margin-bottom: 20px;
margin-left: 20px;
width: 175px;
}

以及输出的 HTML:

<div class="all-boomers">
<a href="/boomers/profile/id/2"><img src="/images/users/medium_thumbs/4fa44866c3561.jpg" alt=""/></a>
      <p class="boomers_name">PC Guy</p>
      <p class="activity_name">IT Guy PC Repair</p>
    </div>
<!-- three more identical section here -->
<div class="all-boomers">
<a href="/boomers/profile/id/6"><img src="/images/users/medium_thumbs/4fa62dff64c44.jpg" alt=""/></a>
      <p class="boomers_name">Cruella Deville</p>
      <p class="activity_name">Dalmation Dog-Sitter</p>
    </div>

即使z-index从样式表中删除,我似乎也无法记录单击事件。到目前为止,这是我的 js 文件:

$(document).ready(function() {

  var boomers = $('.all-boomers');
  var boomersLength = boomers.length;
  var boomersContainer = {};
  $(".all-boomers:eq(4)").attr('id','right-boomer');
  $(".all-boomers:eq(0)").removeClass("all-boomers").addClass("one-fifth first").attr('id','left-boomer');
  var image_left = '<div class="left_arrow_background"></div>';
  var image_right = '<div class="right_arrow_background"></div>';

  $(".boomers_scroller").hover(  
    function(){
        $(image_left).insertBefore('#left-boomer');
        $(image_right).insertAfter('#right-boomer');
    },
    function(){
        $('.left_arrow_background').remove();
        $('.right_arrow_background').remove();
    });

  $("div.left_arrow_background").click(function(){
    var left_boomer = $('#left-boomer').children();
    // store left_boomer in boomerscontainer, then remove it from dom
    console.log('clicked!');

  });
 });

这不仅仅是点击事件......我也尝试过其他鼠标事件,没有任何东西触发控制台测试消息,或者如果我将代码放在 .click 函数中,它不会触发代码。

编辑:添加了第 4 个(相关的 css 样式)

4

2 回答 2

0

你忘了关闭 ready() 函数(或者在粘贴之前复制它 :) 再添加一个 }); 到此代码的底部。这里是孤立的:http: //jsfiddle.net/Q3rDz/

于 2012-05-10T05:40:01.617 回答
-1

固定的!当我单击时,悬停事件仍在发生,因此将单击事件嵌套在悬停事件中可以解决问题。

$(document).ready(function() {
var boomers = $('.all-boomers');
var boomersLength = boomers.length;
var boomersContainer = {};
$(".all-boomers:eq(4)").attr('id','right-boomer');
$(".all-boomers:eq(0)").removeClass("all-boomers").addClass("one-fifth first").attr('id','left-boomer');
var image_left = '<div class="left_arrow_background"></div>';
var image_right = '<div class="right_arrow_background"></div>';
$(".boomers_scroller").hover(       function(){ 
     $(image_left).insertBefore('#left-boomer');
     $(image_right).insertAfter('#right-boomer');
     $("div.left_arrow_background").click(function(){
           var left_boomer = $('#left-boomer').children();
          // store left_boomer in boomerscontainer, then remove it from dom
          console.log('clicked!');    });
 }, 
function(){ 
    $('.left_arrow_background').remove();
     $('.right_arrow_background').remove();
 });
 }); 
于 2012-05-10T16:27:14.530 回答