没有插件的jQuery crossfade

如何解决没有插件的jQuery crossfade

| 这里有很多东西指向用于做交叉渐变和东西的插件,但是没有一个真正适合我的需求。 我的页面上有两件事: 大图像,包含3个或4个小缩略图的div 单击缩略图时,它将读取src并将主图像源更改为新图像。 我如何使它渐入淡出而另一种渐渐淡出(因此在新图像渐隐之前它不会消失) 这是我的代码
$(\'.TnImage\').live(\'click\',function() {
        var newImage = $(this).attr(\'src\');
        var oldImage = $(\'.mainImage\').attr(\'src\')
        $(\'.mainImage\').fadeOut(\'slow\');
        $(\'.mainImage\').attr(\'src\',newImage).fadeIn(\'slow\');
    });
只是为了澄清为什么我不想使用现有的插件,是大多数要求您事先知道要加载的图像列表,缩略图是通过PHPMysqL数据库中检索的,我宁愿不必使2列出一张缩略图和1张主图像,然后将除一个主div以外的所有图像都隐藏在我要显示的图像中。 我看过一个自行车插件,但我不愿意使用它,我知道人们一直在不重新发明轮子,但是如果我继续使用插件来做事,我永远也不会学jQuery工作原理的基本要素。我曾经使用过出色的IMAGESWITCH,但无法与jquery 1.4.3一起使用,并且我需要此版本的html data(),因此以前依靠此功能,现在陷入困境,所以我为什么要问路不使用插件就可以做到这一点。     

解决方法

jQuery循环将执行此操作,但这是一个插件。 为了在没有插件的情况下执行此操作,可以加载图像,然后隐藏除第一个图像外的所有图像。单击缩略图时,然后淡出所选图像。我将在第一张图片中添加一个CSS类,以使其更容易实现。我还要给每个图像一个ID以引用它们。使用CSS将它们放在彼此的顶部。在缩略图标签中,您也需要对大图像的某种引用。
$(\'.TnImage\').live(\'click\',function() {
    $(\'.selected\').fadeOut(500,function(){
        $(this).removeClass(\'selected\');
    });
    $(\'#\'+$(this).attr(\'imgidref\')).delay(250).fadeIn(\'slow\').addClass(\'selected\');
});
我知道这是一个粗略的例子,但是它应该涵盖基本原理。     ,如果我理解了这个问题(除了希望避免使用插件:),jQuery Cycle应该完全按照您的意愿进行。结合使用
fade
过渡和
pager
选项。 http://jsfiddle.net/mattball/xM3cC/     ,由于没有关于没有插件的淡入淡出的答案,这是我想出的解决方案:
<!DOCTYPE html>
<html>
<head>

<script type=\"application/javascript\" src=\"jquery-1.9.1.js\"></script>
<script type=\"application/javascript\" src=\"jquery-ui-1.10.2.custom.min.js\"></script>

<link type=\"text/css\" rel=\"stylesheet\" href=\"jquery-ui-1.10.2.custom.min.css\" />

<title></title>

<script>
var list = new Array();
var increment = 0;

$(function(){
$.when(
    $(\"#image_preload img\").each(function(i,e){
        image = $(this).attr(\'src\');
        list.push(image);
    })
).then(function(){
    rotate()
});
});

function rotate(){
$(\"#deactive\").fadeOut(1000,function(){
});

$(\"#active\").attr(\'src\',list[increment]);

setTimeout(function(){
    increment++;

    if(increment == list.length){
        increment = 0;
    }

    $(\"#deactive\").attr(\'src\',list[increment]);

    $(\"#deactive\").fadeIn(1000,function(){
        rotate();
    });
},5000);
}
</script>

<style>
html,body {
margin: 0px;
padding: 0px;
}

#display {
margin: 0px auto;
position: relative;
text-align: center;
width: 220;
}

#display img {
left: 0px;
margin: 0px auto;
position: absolute;
top: 0px;
}

#image_preload {
display: none;
}
</style>

</head>
<body>

<div id=\"display\">
<img src=\"\" width=\"200\" height=\"200\" alt=\"\" id=\"active\" />
<img src=\"\" width=\"200\" height=\"200\" alt=\"\" id=\"deactive\" />
</div>

<div id=\"image_preload\">
<img src=\"1.png\" width=\"200\" height=\"200\" alt=\"\" />
<img src=\"2.jpg\" width=\"200\" height=\"200\" alt=\"\" />
<img src=\"3.png\" width=\"200\" height=\"200\" alt=\"\" />
<img src=\"4.jpg\" width=\"200\" height=\"200\" alt=\"\" />
<img src=\"5.jpg\" width=\"200\" height=\"200\" alt=\"\" />
</div>

</body>
</html>
可能不是世界上最好的,但是它很简单并且有效。 这是JS Fiddle示例http://jsfiddle.net/DYYCy/     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?