生活
js轮播图代码 、js轮播图代码空间切换
2023-04-19 01:11  浏览:28

JS制作轮播图

轮播图是每个网站中必不可少的元素,那么如何用JS制作轮播图呢?下面我就给大家分享一下。

工具/材料

Sublime Text

01

首先需要在Sublime中创建HTML文档,然后在文档的body区域中加入如下图所示的轮播图内容

02

然后我们需要在style标签中给所添加的轮播图内容声明样式,如下图所示

03

接下来我们就需要在script标签中实现轮播图的动画脚本内容了,如下图所示,注意script标签的type类型一定要是javascript

04

最后我们运行界面程序,你就会看到如下图所示的轮播图了,点击左右的箭头和中间的圆点都可以进行轮播图的切换

js实现轮播代码怎么写?

!DOCTYPE html

html

head

meta charset="UTF-"

title最简单的轮播广告/title

style

body, div, ul, li {

margin: ;

padding: ;

}

ul {

list-style-type: none;

}

body {

background: #;

text-align: center;

font: px/px Arial;

}

#box {

position: relative;

width: px;

height: px;

background: #fff;

border-radius: px;

border: px solid #fff;

margin: px ***to;

}

#box .list {

position: relative;

width: px;

height: px;

overflow: hidden;

border: px solid #ccc;

}

#box .list li {

position: absolute;

top: ;

left: ;

width: px;

height: px;

opacity: ;

transition: opacity .s linear

}

#box .list li.current {

opacity: ;

}

#box .count {

position: absolute;

right: ;

bottom: px;

}

#box .count li {

color: #fff;

float: left;

width: px;

height: px;

cursor: pointer;

margin-right: px;

overflow: hidden;

background: #F;

opacity: .;

border-radius: px;

}

#box .count li.current {

color: #fff;

opacity: .;

font-weight: ;

background: #f

}

/style

/head

body

div id="box"

ul

liimg src="img/images/.jpg" width="" height=""/li

liimg src="img/images/.jpg" width="" height=""/li

liimg src="img/images/.jpg" width="" height=""/li

liimg src="img/images/.jpg" width="" height=""/li

liimg src="img/images/.jpg" width="" height=""/li

/ul

ul

li/li

li/li

li/li

li/li

li/li

/ul

/div

script

var box=document.getElementById('box');

var uls=document.getElementsByTagName('ul');

var imgs=uls[].getElementsByTagName('li');

var btn=uls[].getElementsByTagName('li');

var i=index=; //中间量,统一声明;

var pl***=null;

console.log(box,uls,imgs,btn);//获取正确

//图片切换, 淡入淡出效果我是用(transition: opacity .s linear)做的,不纠结、简单 在css里面

function show(a){    //方法定义的是当传入一个下标时,按钮和图片做出对的反应

for(i=;ibtn.length;i++ ){

btn[i].className='';  //很容易看懂吧?每个按钮都先设置成看不见,然后把当前按钮设置成可见。

btn[a].className='current';

}

for(i=;iimgs.length;i++){ //把图片的效果设置和按钮相同

imgs[i].style.opacity=;

imgs[a].style.opacity=;

}

}

//切换按钮功能,响应对应图片

for(i=;ibtn.length;i++){

btn[i].index=i; //不知道你有没有发现,循环里的方法去调用循环里的变量体i,会出现调到的不是i的变动值的问题。所以我先在循环外保存住

btn[i].onmouseover=function(){

show(this.index);

clearInterval(pl***); //这就是最后那句话追加的功能

}

}

//自动轮播方法

function ***toPl***(){

pl***=setInterval(function(){ //这个paly是为了保存定时器的,变量必须在全局声明 不然其他方法调不到 或者你可以调用***to.pl*** 也许可以但是没时间试了

index++;

index=imgs.length(index=);//可能有优先级问题,所以用了括号,没时间测试了。

show(index);

},)

}

***toPl***();//马上调用,我试过用window.onload调用这个方法,但是调用之后影响到了其他方法,使用***toPl***所以只能这样调用了

//div的鼠标移入移出事件

box.onmouseover=function(){

clearInterval(pl***);

};

box.onmouseout=function(){

***toPl***();

};

//按钮下标也要加上相同的鼠标事件,不然图片停止了,定时器没停,会突然闪到很大的数字上。 貌似我可以直接追加到之前定义事件中。

/script

/body

/html

简单的HTML+js图片轮播?

h5代码:

div id="wrap"

ul id="list"

li10/li

li9/li

li8/li

li7/li

li6/li

li5/li

li4/li

li3/li

li2/li

li1/li

/ul

/div

css代码:

style type="text/css"

@-webkit-keyframes move{

0%{left:-500px;}

100%{left:0;}

}

#wrap{width:600px;height:130px;border:1px solid #000;position:relative;margin:100px ***to;

overflow: hidden;}

#list{position:absolute;left:0;top:0;padding:0;margin:0;

-webkit-animation:5s move infinite linear;width:200%;}

#list li{list-style:none;width:120px;height:130px;border:1px solid red;background: pink;

color:#fff;text-align: center;float:left;font:normal 50px/2.5em '微软雅黑';}

#wrap:hover #list{-webkit-animation-pl***-state:p***sed;}

/style

扩展资料:

轮播图就是一种网站在介绍自己的主打产品或重要信息的传播方式。说的简单点就是将承载着重要信息的几张图片,在网页的某一部位进行轮流的呈现,从而做到让浏览者很快的了解到网站想要表达的主要信息。以及各种新闻网站的头版头条都是用这种方式呈现的重要信息。

轮播图的实现方式:例如:有5张轮播的图片,每张图片的宽度为1024px、高度为512px.那么轮播的窗口大小就应该为一张图片的尺寸,即为:1024×512。之后将这5张图片0px水平相接组成一张宽度为:5120px,高度依然为:512px。最后将这张合成后的大图每次向左移动1024px即可实现轮播图。

求js轮播图代码,有详细注释

!DOCTYPE html

html lang="en"

head

meta charset="UTF-8"

title/title

style type="text/css"

* {

padding: 0;

margin: 0;

list-style: none;

border: 0;

}

.all {

width: 500px;

height: 200px;

padding: 7px;

border: 1px solid #ccc;

margin: 100px ***to;

position: relative;

}

.screen {

width: 500px;

height: 200px;

overflow: hidden;

position: relative;

}

.screen li {

width: 500px;

height: 200px;

overflow: hidden;

float: left;

}

.screen ul {

position: absolute;

left: 0;

top: 0px;

width: 3000px;

}

.all ol {

position: absolute;

right: 10px;

bottom: 10px;

line-height: 20px;

text-align: center;

}

.all ol li {

float: left;

width: 20px;

height: 20px;

background: #fff;

border: 1px solid #ccc;

margin-left: 10px;

cursor: pointer;

}

.all ol li.current {

background: #DB192A;

}

#arr {

displ***: none;

}

#arr span {

width: 40px;

height: 40px;

position: absolute;

left: 5px;

top: 50%;

margin-top: -20px;

background: #000;

cursor: pointer;

line-height: 40px;

text-align: center;

font-weight: bold;

font-family: '黑体';

font-size: 30px;

color: #fff;

opacity: 0.3;

border: 1px solid #fff;

}

#arr #right {

right: 5px;

left: ***to;

}

/style

/head

body

div class="all" id='box'

!--相框--

div class="screen"

ul

li

img src="images/41.jpg" width="500" height="200" /

/li

li

img src="images/42.jpg" width="500" height="200" /

/li

li

img src="images/43.jpg" width="500" height="200" /

/li

li

img src="images/44.jpg" width="500" height="200" /

/li

li

img src="images/45.jpg" width="500" height="200" /

/li

/ul

ol

/ol

/div

div id="arr"

span id="left"lt;/span

span id="right"gt;/span

/div

/div

!-- script src="common.js"/script --

script

function my$(id) {

return document.getElementById(id);

}

function setInnerText(element, content) {

if (typeof element.textContent === "undefined") {

//IE浏览器

element.innerText = content;

} else {

element.textContent = content;

}

}

function animate(element, target) {

//先干掉定时器

clearInterval(element.timeId);

element.timeId = setInterval(function () {

//时时的获取元素的当前的位置

var current = element.offsetLeft;

//每次移动的步数

var step = 10;

//设置每次移动的步数是正数还是负数

step = current  target ? step : -step;

//移动后的当前的位置

current += step;

if (Math.abs(target - current)  Math.abs(step)) {

element.style.left = current + "px";

} else {

clearInterval(element.timeId);

element.style.left = target + "px";

}

}, 20);

}

//获取最外面的div

var box = my$("box");

//获取相框

var screen = box.children[0];

//获取相框的宽度

var imgWidth = screen.offsetWidth;

//获取ul

var ulObj = screen.children[0];

//获取ul中的li

var ulLiObj = ulObj.children;

//获取ol

var olObj = screen.children[1];

//获取的是左右焦点的div

var arr = my$("arr");

//获取左边的按钮

var left = my$("left");

//获取右边的按钮

var right = my$("right");

var pic = 0;

//页面加载后先创建小按钮,根据ul中的li个个数来创建li,把li加入到ol中

for (var i = 0; i  ulLiObj.length; i++) {

//创建li

var liObj = document.createElement("li");

//把li加入到ol中

olObj.appendChild(liObj);

setInnerText(liObj, (i + 1)); //兼容代码

//为每个ol中的li添加一个自定义属性存储索引值

liObj.setAttribute("index", i);

//为每个li注册鼠标进入事件

liObj.onmouseover = function () {

//先把ol中所有的li的背景颜色全部干掉

for (var j = 0; j  olObj.children.length; j++) {

olObj.children[j].removeAttribute("class");

}

//设置当前鼠标进入的li有背景颜色

this.className = "current";

//移动ul

//获取鼠标进入的ol中的li的索引值

pic = this.getAttribute("index");

animate(ulObj, -pic * imgWidth);

};

}

//***个标签设置颜色

olObj.children[0].className = "current";

//追加一个图片到ul中

ulObj.appendChild(ulObj.children[0].cloneNode(true));

//页面加载之后自动移动

var timeId = setInterval(f1, 1000);

//鼠标进入

box.onmouseover = function () {

arr.style.displ*** = "block";

clearInterval(timeId);

}

//鼠标离开

box.onmouseout = function () {

arr.style.displ*** = "none";

timeId = setInterval(f1, 1000);

}

//右边焦点

right.onclick = f1;

function f1() {

//判断是否到达最后一张

if (pic == ulLiObj.length - 1) {

//跳转到***张

pic = 0;

ulObj.style.left = -pic * imgWidth + "px";

}

pic++;

//调用动画函数

animate(ulObj, -pic * imgWidth);

//刷一遍

for (var i = 0; i  olObj.children.length; i++) {

olObj.children[i].removeAttribute("class");

}

//***个按钮的颜色

if (pic == ulLiObj.length - 1) {

olObj.children[0].className = "current";

} else {

olObj.children[pic].className = "current";

}

};

//左边焦点

left.onclick = function () {

//判断是否到达***张图片

if (pic == 0) {

//跳转到第六张图片

pic = ulLiObj.length - 1;

ulObj.style.left = -pic * imgWidth + "px";

}

pic--;

//调用动画函数

animate(ulObj, -pic * imgWidth);

//刷一遍

for (var i = 0; i  olObj.children.length; i++) {

olObj.children[i].removeAttribute("class");

}

olObj.children[pic].className = "current";

}

/script

/body

/html

js如何制作图片轮播

工具/材料

Sublime Text

01

首先在Sublime Text下面准备一个html和5张图片,图片宽高为600px和400px,如下图所示

02

然后在HTML页面中布局轮播图的结构,如下图所示,主要包括图片区域,圆形按钮,左右箭头

03

接下来需要给轮播图页面布局声明一些样式,请按照下图所示的样式代码进行声明

04

最后就是实现轮播图的JS脚本功能,如下图所示,主要包括前进,后退,自动播放的功能

05

最后运行页面,你就会看到下图所示的轮播图效果,点击圆圈或者左右箭头可以切换轮播图

关于js轮播图代码和js轮播图代码空间切换的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

发表评论
0评