js-组件-轮播
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>轮播</title>
<style>
*{
margin: 0;
padding: 0;
border: 0;
list-style: none;
vertical-align: baseline;
}
img{
display: block;
float: left;
}
#container{
position: relative;
width: 500px;
overflow: hidden;
height: 375px;
margin: 0 auto;
}
#list{
position: absolute;
z-index: 1;
width: 3500px;
}
#list img{
width: 500px;
}
#prev,#next,#button{
position: absolute;
z-index: 2;
}
#button{
left: 190px;
bottom: 20px;
}
#button a{
display: block;
float: left;
width: 20px;
height: 20px;
background-color: #fff;
border-radius: 10px;
margin: 2px;
}
#button a.on{
background-color: #000;
}
#prev,#next{
background-color: rgba(0,0,0,0.3);
width: 80px;
height: 80px;
top: 150px;
display: none;
}
#prev:hover,#next:hover{
background-color: rgba(0,0,0,0.7);
cursor: pointer;
}
#next{
right: 0;
}
#prev span,#next span{
display: block;
border: 1px solid #fff;
border-left: none;
border-bottom: none;
width: 50px;
height: 50px;
transform:rotate(45deg);
margin-top: 15px;
}
#container:hover #next,#container:hover #prev{
display: block;
}
#prev span{
transform:rotate(-135deg);
margin-left: 25px;
}
</style>
</style>
<script>
window.onload=function(){
var container=document.getElementById('container');
var list=document.getElementById('list');
var prev=document.getElementById('prev');
var next=document.getElementById('next');
var buttons=document.getElementById('buttons').getElemenstByTagName('a');
var index=1;
var timer=setInterval(function(){
next.onclick();
},2000);
var moved=false;
function move(offset){
var newleft=parseInt(list.style.left)+offset;
var time=300;
var interval=30;
var speed=offset/(time/interval);
function go(){
if((speed<0&&newleft>list.style.left)||(speed>0&&newleft<list.style.left)){
moved=true;
parseInt(list.style.left)+speed+'px';
setTimeout=(go,interva);
}else{
moved=false;
list.style.left=newleft+'px';
if(newleft<-2500){
list.style.left=-500+'px';
}
if(newleft>-500){
list.style.left=-2500+'px';
}
}
}
go();
}
function showbutton(){
for(var i=0;i<buttons.length;i++){
if(buttons[i].className=='on'){
buttons[i].className='';
break;
}
}
buttons[index-1].className='on';
}
next.onclick=function(){
if(!moved){
move(-500);
if(index==5){
index=1;
}
index+=1;
showbutton();
}
}
prev.onclick=function(){
if(!moved){
move(500);
if(index==1){
index=5;
}
index-=1;
showbutton();
}
}
}
for(var i=0;i<buttons.length;i++){
buttons[i].onclick=function(){
if(this.className='on'){
return;
}
newindex=i+1;
var offset=(newindex-index)*(-500);
if(!moved){
move(offset);
index=newindex;
showbutton();
}
}
}
container.onmouseover=function(){
clearInterval(timer);
}
container.onmouseout=function(){
timer=setInterval(function(){
next.onclick();
},2000);
}
</script>
</head>
<body>
<div id="container">
<div id="list" syle="left:-500px">
<img src="5.jpg">
<img src="1.jpg">
<img src="2.jpg">
<img src="3.jpg">
<img src="4.jpg">
<img src="5.jpg">
<img src="1.jpg">
</div>
<div id="prev"><span></span></div>
<div id="next"><span></span></div>
<div id="buttons">
<a href="javascript:;" class="on"></a>
<a href="javascript:;"></a>
<a href="javascript:;"></a>
<a href="javascript:;"></a>
<a href="javascript:;"></a>
</div>
</div>
</body>
</html>
js-组件-轮播的更多相关文章
- 使用原生js将轮播图组件化
代码地址如下:http://www.demodashi.com/demo/11316.html 这是一个轮播图组件,这里是代码地址,需要传入容器的id和图片地址,支持Internet Explor ...
- 原生js焦点轮播图
原生js焦点轮播图主要注意这几点: 1.前后按钮实现切换,同时注意辅助图2.中间的button随着前后按钮对应切换,同时按button也能跳转到相应的index3.间隔调用与无限轮播.4.注意在动画时 ...
- 原生js实现轮播图
原生js实现轮播图 很多网站上都有轮播图,但找到一个系统讲解的却很难,因此这里做一个简单的介绍,希望大家都能有所收获,如果有哪些不正确的地方,希望大家可以指出. 原理: 将一些图片在一行中平铺,然后计 ...
- js实现轮播图效果(附源码)--原生js的应用
1.js实现轮播图效果 <!DOCTYPE html><html lang="en"><head> <meta charset=" ...
- js编写轮播图,广告弹框
1.轮播图 js编写轮播图,需要用到setInterval(计时器):先给一个div,里面放轮播图的图片,将轮播图的图片明明为相同样式的:如:banner1.jpg,banner2.jpg,banne ...
- js原生轮播
js原生轮播 今天用js做了轮播图,做的不怎么好,希望大家能够看懂. 效果: 1.鼠标放在轮播图上自动停止 2.鼠标离开轮播图自动播放 3.鼠标点击轮播图上的小圆点跳转到相应的图上. 代码: < ...
- js实现轮播图
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 封装一个简单的原生js焦点轮播图插件
轮播图实现的效果为,鼠标移入左右箭头会出现,可以点击切换图片,下面的小圆点会跟随,可以循环播放(为了方便理解,没有补2张图做无缝轮播).本篇文章的主要目的是分享封装插件的思路. 轮播图我一开始是写成非 ...
- 原生JS实现轮播图的效果
原生JS实现轮播图的效果: 只要缕清了全局变量index的作用,这个轮播图也就比较容易实现了:另外,为了实现轮这个效果,有几处clearInterval()必须写上.废话不多说,直接上代码,修复了几个 ...
- vue 组件轮播联动
组件轮播联动我使用的是 el-carousel 组件,具体代码如下: <el-carousel trigger="click" :interval="3000&qu ...
随机推荐
- Response.Write() Alert后页面布局改变
根据peter_zhang给出的解决方案,原文URL:http://www.cnblogs.com/starxp/articles/1939032.html 使用Page.ClientScript.R ...
- Struts加入拦截器后取不到页面参数
在Struts2的demo项目中添加了一个简单的拦截器,突然发现,Action中取不到页面的参数了 这也是很蛋疼的事情,还好这个比较简单,稍微一查就发现问题: Struts2中很多的功能是用拦截器实现 ...
- IOS开发-OC学习-NSTimer的使用
上一篇博客中在改变属性值的时候使用了timer进行自动改变.关于NSTimer的更详细的用法如下: 定义一个NSTimer类型的timer,和一个count,其中timer是定时器,count是计数的 ...
- Makefile常用调试方法
转载自 陈皓<跟我一起写 Makefile><GNU Make项目管理> GNU make 提供了若干可以协助调试的内置函数以及命令行选项. 1.warning函数 $(war ...
- Java XML解析器
使用Apache Xerces解析XML文档 一.技术概述 在用Java解析XML时候,一般都使用现成XML解析器来完成,自己编码解析是一件很棘手的问题,对程序员要求很高,一般也没有专业厂商或者开源组 ...
- Java中String的split()方法的一些需要注意的地方
public String[] split(String regex, int limit) split函数是用于使用特定的切割符(regex)来分隔字符串成一个字符串数组,这里我就不讨论第二个参数( ...
- c++ split()实现
在c++中,没有java与python中定义的split()功能的函数,于是自己实现之. 情况1,适用范围,分隔符为字符.思路,记录分隔符的位置,判断需要截取的字符串的下标范围. vector< ...
- 七 APPIUM Android 定位方式
1.定位元素应用元素 1.1通过id定位元素 Android里面定位的id一般为resrouce-id: 代码可以这样写: WebElement element = driver.findElem ...
- post请求时2种传参方式
@Testpublic void dopost(){ String httpurl = "https://jin.caimao.com/api/user/loginSalt"; M ...
- 【转】sql语句的优化分析
开门见山,问题所在 sql语句性能达不到你的要求,执行效率让你忍无可忍,一般会时下面几种情况. 网速不给力,不稳定. 服务器内存不够,或者SQL 被分配的内存不够. sql语句设计不合理 没有相应的索 ...