写给代码小白:运用JavaScirpt实现大图滚动

在大家平时浏览网页时,一定经常看到许多首页都会布置一些精美、酷炫的带有滚动效果的图片,使网站更具有吸引力(如图)。今天给大家分享一些简单的运用H5和css3的内容配合原生JS来实现大图滚动的方法. (由于本人也是刚刚接触H5和JS,许多东西都是最基础的,希望来往的大神轻点喷😂 )

大图滚动.png


准备过程

新建文件夹,并命名,暂时命名为"滚动"即可.另外新建文件夹"imgs",选几张自己喜欢的图片放到里面。
然后打开你的代码编辑器,(本人用的 Hbuidler,功能足够强大,在这里也推荐给大家...),新建HTML文件,命名为"index.html",同时新建css和js文件,命名为"sroll",至此准备工作结束。

HBuilder.png

准备工作

简单布局

切换到html页面,编辑代码如下:

<div class="wrap">
   <div class="middle">
       <div><img src="imgs/1.jpg"/></div>
       <div><img src="imgs/2.jpg"/></div>
       <div><img src="imgs/3.jpg"/></div>
       <div><img src="imgs/4.jpg"/></div>
   </div>
   <div class="page_move" id="next" style="top: 950px">  >  </div>
   <div class="page_move" id="last" style="top: 0"><</div>
   <input type="button" class="pageBtn" value="1" />
   <input type="button" class="pageBtn" value="2" />
   <input type="button" class="pageBtn" value="3" />
   <input type="button" class="pageBtn" value="4" />
</div>

添加css样式

编辑下方的代码保存至.css文件中。
在设置样式时,采用了定位,通过改变left值,实现滚动的效果。

//清除样式
*{
    margin: 0;
    padding: 0;
    border: 0;
}
//简单设置最外层属性。值得注意的是这里用到'overflow:hidden'使超出div部分图片隐藏。
.wrap{
    width: 1000px;
    height: 550px;
    position: relative;
    overflow: hidden;
    margin: 0 auto;
}
//给".middle"设置定位而且在这用到'transition',使图片在移动时有滚动的效果。
.middle{
    height: 550px;
    position: absolute;
    top: 0;
    left: 0;
    transition: all 0.5s;
}
// 在内层div处设置浮动,让所有图片排成一列。
.middle>div{
    width: 1000px;
    height: 550px;
    text-align: center;
    line-height: 350px;
    float: left;
    font-size: 50px;
}
.middle>div>img{
    width:100%;
// 由于只是简单的实现一下,这里的方向直接用尖括号代替了,毕竟程序猿都不喜欢麻烦😂。
.page_move{
    width: 25px;
    height: 50px;
    color: white;
    text-align: center;
    line-height: 100px;
    background-color: #000000;
    opacity: 0.4;
    position: absolute;
    top: 150px;
}
.pageBtn{
    position: relative;
}
.wrap>input{
    width: 50px;
    height: 20px;
    color: white;
    background-color: rgba(0,0,0,0.3);
}

注意:给".middle"设置定位时要给left和top初始值,否则在第一张图片移动时,不会产生滚动效果。其次其width是在JS中给出,这一点就根据个人喜好,本人觉得放到JS会比较方便日后修改。
添加完样式后,效果如下图:

scroll.png

scroll_html.png

JS部分

原生JS代码:

//  获取各项变量
var wrapDiv = document.querySelector(".wrap");
var middleDiv = document.querySelector(".middle")
var divs = document.querySelectorAll(".middle>div");
var nextBtn = document.getElementById("next");
var lastBtn = document.getElementById("last");
var pageBtn = document.querySelectorAll(".pageBtn");
// 设置定时器,和页码page
var page = 0;
var timer = null;
// middle 宽
// 获取到wrap的宽度保存到变量里
var w = wrapDiv.offsetWidth;
middleDiv.style.width = w * divs.length + "px";
// middle移动
function pageTurn() {
    middleDiv.style.left = -w * page + "px";
}
// 滚动:这里的direction是自己设置的参数,用来判断是向左滚动还是向右滚动
function scroll(direction) {
    if (direction == "next") {
        page++;
        if (page > divs.length - 1) {
            page = 0;
        }
    } else {
        page--;
        if (page < 0) {
            page = divs.length - 1;
        }
    }
    pageTurn();
}
// 利用定时器实现自动滚动
function autoScroll() {
    clearInterval(timer)
    timer = setInterval(function() {
        scroll("next");
    }, 1500)
}
nextBtn.onclick = function() {
    clearInterval(timer);
    scroll("next");
}
nextBtn.onmouseout = function() {
    autoScroll();
}
lastBtn.onclick = function() {
    clearInterval(timer);
    scroll();
}
lastBtn.onmouseout = function() {
    autoScroll();
}
window.onload = function() {
    autoScroll();
}
wrapDiv.onmouseover = function() {
    clearInterval(timer);
}
wrapDiv.onmouseout = function() {
    autoScroll();
}
// 利用for循环,实现点击页码来切换图片
for (var i = 0; i < divs.length; i++) {
    pageBtn[i].index = i;//给input设置一个index属性,将input下标保存起来
    pageBtn[i].onmouseover = function() {
        page = this.index;//将input的下标传递给page 
        pageTurn();
    }
    pageBtn[i].onmouseout = function() {
        autoScroll();
    }
}

将以上代码保存在.js文件中。

引用css文件和js文件

在html文件中添加css文件需要输入的代码:
"<link rel="stylesheet" type="text/css" href="scroll.css"/>"
其中"href"的等号后面索要添加的就是你css文件的相对路径。


css文件引用.png

在html文件中添加js文件需要输入的代码:
<script src="scroll.js" type="text/javascript" charset="utf-8"></script>
js文件的相对路径要添加自"src"的等号后面


js文件的引用.png

到此为止利用原生js来实现图片滚动的方法就介绍完毕,效果图发给大家。
滚动.gif

运用jquery实现大图滚动

如果觉得原生js很麻烦的话,大家也可以用jquery来实现。
首先到官网去下载jquery库文件,下载页面:http://jquery.com/download/

jquery-download.png

进入官方的下载页面后点击红色框的链接即可下载了,当然若是不打算兼容IE浏览器选择黄色框会是更好的选择。
以下是运用jQuery库写的图片滚动:

$(function(){
    $('.middle').css('width', function(){
        return $('.wrap').width() * $('img').length;
    })
    function scroll(){
        page++;
        if (page > $('img').length - 1) {
            page = 0;
        }
        $('.middle').animate({
            left: -$('.wrap').width() * page
        }, 1000)
    }
   var timer = null;
   function autoscroll(){
       timer = setInterval(function(){
           scroll();
       },2000)
   }
   autoscroll();
   var page = 0;
   $('.next').click(function (){
       clearInterval(timer);
       scroll();
   }).mouseout(function(){
       autoscroll();
   })
   $('.last').click(function(){
       clearInterval(timer);
       page--;
       if (page < 0) {
           page = $('img').length - 1;
       }
       $('.middle').animate({
           left: -$('.wrap').width() * page
       }, 1000)
   }).mouseout(function(){
       autoscroll();
   })
})```
由于本篇文章主要介绍的是运用原生JS实现大图滚动的效果,jQuery方面便无须赘述,有兴趣的可以
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,602评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,442评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,878评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,306评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,330评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,071评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,382评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,006评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,512评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,965评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,094评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,732评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,283评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,286评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,512评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,536评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,828评论 2 345

推荐阅读更多精彩内容