首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Jquery插件悬停效应不起作用

Jquery插件悬停效应不起作用
EN

Stack Overflow用户
提问于 2014-02-23 18:39:15
回答 1查看 92关注 0票数 0

谢谢大家看我的问题。

我正在尝试写我自己的jQuery图片库插件。它工作良好,当页面加载,但它不工作,当我点击照片链接到照片部分。

以下是链接:

api/flat-page.html

以下是我所做的:

代码语言:javascript
复制
$(function() {
  for (var i = 1; i <= 12; i++) {
   var name = i + '.jpg';
   if(i<10) name = '0' + name;
   var img = $('<img class="galleryImage" src="pic/'+ name + '"/>');
   $("#gallery").append(img);
  };
  var g = new  PS.Gallery('gallery');
});

下面是插件代码:(在页面刷新中,它可以工作,但当我单击菜单链接并转到div时,悬停效果就不起作用了。)

代码语言:javascript
复制
(function(ns){
        ns.Gallery = function(id){
        var gallery = $('#'+ id);
        var images  = gallery.find('.galleryImage');

        var xPos = 50;
        var yPos = 50;
        var gWidth = gallery.width();

            images.each(function(idx,el){
                var img = $(el);
                img.data('homeX',xPos);
                img.data('homeY',yPos);
                img.data('currentScale',1);
                img.css({
                    'left':xPos,
                    'top':yPos,
                    'width':img.width() * 0.25
                });
                xPos += 95;
                if(xPos > gWidth - 100){

                    xPos = 50;
                    yPos += 115;

                }

                img.hover(
                    function(event){
                    var target = $(event.target);
                        animateImage(target,500,target.data('homeX'),target.data('homeY'),2);
                    },function(event){
                        returnAllToNormal();
                    }
                );
                var returnAllToNormal = function(){
                    images.each(function(idx,el){
                        var img = $(el);
                        animateImage(img,500,img.data('homeX'),img.data('homeY'),1);
                    });
                }
                var animateImage = function(img,duration,left,top,scale){
                        img.stop();
                        img.css('textIndent',img.data('currentScale'));
                        img.animate({
                            'left':left,
                            'top':top,
                            'textIndent':scale
                        },
                        {
                        duration:duration,
                        step:function(now,fx){
                            if(fx.prop === 'textIndent'){
                                img.data('currentScale',now);
                                img.css('transform','scale(' + now + ')');
                            }else if(fx.prop === 'left'){
                                img.css('left',now);
                            }else if(fx.prop==='top'){
                                img.css('top',now);
                            }
                        }
                    });
                }
            });
        }
    }(window.PS = window.PS || {}));

我是不是把插件打到正确的位置了?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-02-23 18:55:05

当我将您的div#con的最高值改为-2500 of时,您的画廊就有点崩溃了。在进一步的探索中,了解到你正在存储单个图像的当前x和y位置,这就造成了这个问题。

与其存储当前值,不如对当前值进行播放。以下是有问题的代码:

代码语言:javascript
复制
var img = $(el);
img.data('homeX',xPos);
img.data('homeY',yPos);
img.data('currentScale',1);
img.css({
    'left':xPos,
    'top':yPos,
    'width':img.width() * 0.25
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21972695

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档