执行fadein追加css,基于CSS3完成淡入(fadeIn)淡出(fadeOut)结果

本文介绍了如何使用CSS3的动画效果实现图片淡入淡出的无缝轮播,通过预定义的样式类配合JavaScript进行切换,提供了一个高效且平滑的过渡效果。关键在于利用opacity和CSS3的transition属性。示例代码展示了具体的实现细节,适用于移动端,但在IE中可能存在背景图片显示问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

网上的淡入淡出结果大多是遵照jquery中fadeIn和fadeOut的要领运用js来掌握元素的透明度到达目标,但瑕玷是有细微的卡顿感,而且运转效力平常。 这里供应别的一个思绪,即经由过程预先定义好的css款式掌握图片透明度的过渡, 这类要领过渡腻滑,过渡的结果基于css3的animation,所以效力高些。 思绪是将淡入,淡出的结果做成预先定义好的款式类,然后用JS转变元素的类来到达图片轮播。(注重:由于是基于CSS3的animation,在挪动端做的兼容性测试表现不错,桌面端临时没有发明太大的题目。但IE关于css的background支撑不太好,外链图片偶然会有题目。)

基于CSS3淡入淡出结果的图片自动轮播DEMO

症结点在于fadeIn和fadeOut之间的透明度切换:/* 轮播图片默许的款式*/

.bg {

position: absolute;

left: 0;

top: 0;

width: 100%;

height: 100%;

-webkit-transition: opacity 2s linear;

-moz-transition: opacity 2s linear;

-o-transition: opacity 2s linear;

transition: opacity 2s linear;

opacity:0;

filter:alpha(opacity=0);

}

.fadein{

opacity:100;

filter:alpha(opacity=100);

}

PS:轮播图片默许透明度为0,设置一个opacity=100名为fadein的类运用JS掌握其与默许透明度的切换,本篇博客的轮播要领是自动的一张张切换,并没有交互性, 运用触控摆布滑动图片的轮播请猛戳俺的另一篇博客:原生JS完成滑动图片轮播

而JS方面则是经由过程猎取imgs数组,轮播个中寄存图片的div, 要领是掌握图片div的class。

空话不多说,上代码:

HTML(后插进去的图片显现在前):

CSS:.bg {

position: absolute;

left: 0;

top: 0;

width: 100%;

height: 100%;

-webkit-transition: opacity 2s linear;

-moz-transition: opacity 2s linear;

-o-transition: opacity 2s linear;

transition: opacity 2s linear;

opacity:0;

}

#bg1 {

background: url(http://i1.tietuku.com/7b57a678c8999dbas.jpg) no-repeat;

background-size: cover;

}

#bg2 {

background: url(http://i1.tietuku.com/1182f22573e6051fs.jpg) no-repeat;

background-size: cover;

}

.fadein {

opacity: 100;

filter: alpha(opacity=100);

}

JS:// 替代class到达淡入淡出的结果

function fadeIn(e) {

e.className = "bg fadein"

};

function fadeOut(e) {

e.className = "bg"

};

//说明图片数组中当前的轮播图片

cur_img = document.getElementById("imgs").children.length - 1;

//图片轮播函数

function turnImgs(imgs) {

var imgs = document.getElementById("imgs").children;

if (cur_img == 0) {

fadeOut(imgs[cur_img]);

cur_img = imgs.length - 1;

fadeIn(imgs[cur_img]);

} else {

fadeOut(imgs[cur_img]);

fadeIn(imgs[cur_img - 1]);

cur_img--;

}

}

//设置轮播距离

setInterval(turnImgs, 3000);

demo中只用了两张图片,假如须要插进去更多的图片,能够在id=“imgs”的div中到场一个新的子div ,class加上bg即可,然后在CSS中到场该div的形貌,比方HTML中到场

background: url(图片地点) no-repeat;

background-size: cover;

}

即可。

FadeOut 是一种常见的音频处理技术,用于平滑地降低音频的音量,给人一种逐渐消失的感觉,常用于音频淡入淡出效果或音频的停止过程中。在编程中,特别是涉及音频处理的库(如Python的PyDub,JavaScript的Web Audio API,或者游戏开发中的Unity等)中,FadeOut通常涉及到调整音频片段的 gain(音量)属性。 例如,在Python的PyDub库中,你可以这样实现一个音频片段的FadeOut操作: ```python from pydub import AudioSegment # 加载音频文件 audio = AudioSegment.from_file("path_to_your_audio_file.mp3") # 指定淡出时间(单位通常是毫秒) fade_duration = 2000 # 2秒 # 创建FadeOut效果 faded_audio = audio.fade_out(fade_duration) # 写回文件或保存为新的音频文件 faded_audio.export("output_faded_audio.mp3", format="mp3") ``` 在JavaScript的Web Audio API中,可以使用`GainNode`和`linearRampToValueAtTime`方法: ```javascript // 假设audioContext是已经创建好的AudioContext实例 const audio = audioContext.createMediaElementSource(yourAudioElement); const gainNode = audioContext.createGain(); audio.connect(gainNode); gainNode.connect(audioContext.destination); // 淡出时间(以秒为单位) const fadeDurationSeconds = 2; const timeConstant = fadeDurationSeconds / 1000; // 1000ms per second // 设置初始音量 gainNode.gain.value = 1; // 开始淡出 audioContext.currentTime = audioDuration - fadeDurationSeconds; gainNode.gain.linearRampToValueAtTime(0, audioContext.currentTime + timeConstant); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值