- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我找到了一个使用 jQuery 制作的图像 slider 的教程。我想在纯 JS 中重新创建完全相同的功能,但在将 jQuery 的动画函数功能转换为纯 JS 时遇到了一些问题。
这是它的代码。(我面临的问题是不透明度的变化)
HTML:(来自教程)
<!DOCTYPE html>
<html>
<head>
<title>Jquery Slider Demo</title>
<script src="jquery-2.1.3.min.js" type="text/javascript" ></script>
<script type="text/javascript" src="script.js"></script>
<link rel="stylesheet" type="text/css" href="style.css">
</head>
<body>
<div class="slides">
<img src="img/1.jpg" />
<img src="img/2.jpg" />
<img src="img/3.jpg" />
<img src="img/4.jpg" />
</div>
</body>
</html>
JS(来自教程):
$(function(){
// initalizing the first image to class 'top'
$('.slides img:first').addClass('top');
//function to alter the image index by changing the class
var change = function (){
var curr = $('.slides img.top');
var next = curr.next();
// if the next image is not available then
// set the class-top to the first image
// then vanish the current image to
// show the previous next image
if(!next.length){
next = $('.slides img:first');
next.addClass('top');
curr.animate({opacity: 0.0},1000, function() {
curr.removeClass('top');
curr.css({opacity: 1.0});
});
}else{
// pick the next image
// set the opacity to 0
// den use animation to make it appear
// above the top image
next.css({opacity: 0.0})
.addClass('top')
.animate({opacity: 1.0}, 1000, function() {
curr.removeClass('top');
});
}
}
// repeat the function execution for every 3 secs
setInterval(change, 3000 );
});
到目前为止我所拥有的:
(function(){
var list = document.getElementsByTagName('img');
for (var i=0; i<list.length; i++ ) {
list[i].addEventListener('transitionend', function(){
this.style.opacity = "1";
this.classList.remove('top');
})
};
list[0].classList.add('top');
var change = function () {
var curr = document.querySelector('img.top');
var next = curr.nextElementSibling;
if(next == undefined) {
next = list[0]
next.classList.add('top');
curr.style.opacity = "0";
}
else {
curr.style.opacity = "0";
console.log('i am working')
next.classList.add('top');
}
}
setInterval(change,3000);
})();
最佳答案
正如在您的问题下面的评论中提到的,在没有 jQuery 的情况下,获得漂亮的淡入淡出效果的最佳方法是 CSS。
function slider(){
var list = document.getElementsByTagName('img');
list[0].classList.add('top');
var change = function () {
console.log('I am working');
var curr = document.querySelector('img.top');
var next = curr.nextElementSibling;
if(next == undefined) {
next = list[0]
}
curr.classList.remove('top');
next.classList.add('top');
}
setInterval(change,3000);
}
.slides img {
/* this is just for the demo slider to run as a slider... */
position:absolute;
top:0;
left:0;
width:100%;
/* This is the CSS for fading */
-webkit-transition: 1s all linear;
opacity: 0;
}
.slides img.top {
opacity: 1;
}
<body onload="slider();">
<div class="slides">
<img src="https://lorempixel.com/400/200/sports/image 1" />
<img src="https://lorempixel.com/400/200/sports/image 2" />
<img src="https://lorempixel.com/400/200/sports/image 3" />
<img src="https://lorempixel.com/400/200/sports/image 4" />
</div>
</body>
关于javascript - 将用 jQuery 编码的图像 slider 转换为纯 JS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45761330/
我正在尝试使用 div 和 javascript 创建一个简单的 slider 。我设置了一个包含六个图像的 div 和一个箭头,每次单击它时,该箭头都会将包含图像的容器拍摄为 528px(每个图像的
我使用flexslider,当我按照他们网站上的说明操作时,它不适用于多个 slider ,这是代码: 我需要在两个 slider 上都有一个 Controller 导航,说明如下: http://w
这是一个困难的问题,我一直在努力让它发挥作用。它确实起作用了一半,但我认为逻辑是问题所在。下面我会解释一下情况和问题。 情况:想要使用 slider Controller 来选择房间内可以占用的成人、
我制作了一个简单的 slider ,它适用于普通表格,但是当我尝试将该 slider 用于我的自定义 Bootstrap 表格时,只有第一个、第三个 slider 出现,而不是第二个和第四个。 var
我正在使用 Bootstrap slider http://seiyria.com/bootstrap-slider/对于贷款产生者。这里没问题。 但是我必须使用相同的 slider ,一个位于顶部,
我正在使用光滑的 slider 。我在页面上有三个 slider ,它们都有相同的类和光滑的选项。但是,我想要三个不同的灵活“autoplaySpeed”选项,或者为所有三个 slider 分别添加随
我试图用 Slider2 和 Slider3 的总和来更新 Slider1 的值,但它只显示 Slider1 或 Slider2 的值,以移动的为准。我在更新 Slider1 的值时犯了一些错误。 H
我使用 css 和 html 以及 jQuery 创建了一个 slider 。该 slider 与下一个按钮配合使用效果很好,但与上一个按钮配合使用效果不佳。 假设我在第一张幻灯片上有五个元素,总共有
我正在制作一个包含多个 slider 的页面,其中 slider 的数量和选项根据用户的不同而不同。我遇到一个问题,所有 slider 都已创建并显示,但只有最后一个 slider 是可拖动的。 简单
我正在尝试获取 jQuery-UI slider 的当前值在 JavaScript 函数中,它不起作用。如果我这样做 $("#someParticularDOMObject").find(".sl
我正在尝试在 JQuery UI 中的 slider 的 slide 和 change 事件上同时更新多个 slider 。 我有如下代码: $(function() { var totalS
我正在使用来自 Filament 组的 jQuery UI slider ,它将 SELECT 元素转换为 slider 。它工作正常。现在我想使用 JavaScript 以编程方式将 slider
是否可以在 NIVO SLIDER 中将幻灯片设为链接? 最佳答案 嗯,不知道是不是一样,但是...... 我在 IE 所有版本中的链接都有问题,其他浏览器工作正常,通过添加解决: backgroun
在我的项目中,我使用了光滑的 slider 插件(http://kenwheeler.github.io/slick/) 我需要更改单词的默认点导航。单击单词后应更改幻灯片。 最佳答案 这是更新的代码
我正在使用 nivo slider (默认主题),我将上一个和下一个箭头定位在图像旁边(不是在图像顶部),我想知道是否有一种方法可以始终显示下一个和上一个箭头(现在箭头仅在您将鼠标悬停在图像上时显示)
我正在使用 Slider在我的 javaFX 项目中,我有一个 Label当我移动 slider 时会更新。 我想要 Label在我拖动 Slider 时进行更新不仅在拖放时。 这是我的代码: be
我有一个事件站点,一页上有 3 个光滑的 slider ,通常光滑的 slider 不会初始化,而是我只看到所有的图像,有时如果我刷新它们都开始工作。 https://au.hairandme.com
我想让每年一定数量的海龟(由 slider 控制)死亡。到目前为止,我明白了,它可能非常简单,但我似乎无法使其发挥作用。多谢! to hunting let huntedturtles (count
我有一个带背景图像的全宽 slider 。 slider 高度根据图像进行响应,因此它始终在屏幕的一侧到另一侧显示 100% 的图像。 现在我尝试将内容(文本)放置在 slider 内,使其位于内容网
我对 Swiper slider 有一些问题。当我滚动到 slider 的末尾时,可以看到一些空白区域。 http://take.ms/siqXj swiper = new Swiper(profil
我是一名优秀的程序员,十分优秀!