电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

原生js實現輪播圖特效

瀏覽:137日期:2024-05-10 09:20:33

輪播圖也稱為焦點圖,是網頁中比較常見的網頁特效。

功能需求:

​ 1.鼠標經過輪播圖模塊,左右按鈕顯示,離開隱藏左右按鈕。

​ 2.點擊右側按鈕一次,圖片往左播放一張,以此類推,左側按鈕同理。

​ 3.圖片播放的同時,下面小圓圈模塊跟隨一起變化。

​ 4.點擊小圓圈,可以播放相應圖片。

​ 5.鼠標不經過輪播圖,輪播圖也會自動播放圖片。

​ 6.鼠標經過,輪播圖模塊, 自動播放停止。

此文章的代碼為一個完整的輪播圖的實現代碼,復制即可運行

實現效果由于大小問題無法上傳,可自行觀看淘寶或京東首頁輪播圖效果

html文件:

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> <title>Document</title> <link rel='stylesheet' href='http://www.hdgsjgj.cn/bcjs/css/index.css' rel='external nofollow' > <script src='http://www.hdgsjgj.cn/bcjs/js/animate.js'></script> <script src='http://www.hdgsjgj.cn/bcjs/js/index.js'></script></head><body> <div class='box'> <ul> <li><img src='http://www.hdgsjgj.cn/bcjs/img/focus.jpg' alt=''></li> <li><img src='http://www.hdgsjgj.cn/bcjs/img/focus1.jpg' alt=''></li> <li><img src='http://www.hdgsjgj.cn/bcjs/img/focus2.jpg' alt=''></li> <li><img src='http://www.hdgsjgj.cn/bcjs/img/focus3.jpg' alt=''></li> </ul> <ol> </ol> <div class='arr-l'> < </div> <div class='arr-r'> > </div> </div></body></html>

css文件:

* { margin: 0; padding: 0; outline: none;}.box { overflow: hidden; position: relative; height: 455px; width: 721px; background-color: pink; margin: 50px auto;}.box ul { position: absolute; top: 0; left: 0; width: 600%;}.box ul li { list-style: none; float: left;}.box ol { position: absolute; bottom: 10px; left: 100px; background-color: rgba(255, 255, 255, .3); border-radius: 8px; list-style: none; height: 10px; padding: 2px 5px;}.box ol li { cursor: pointer; float: left; height: 8px; width: 8px; border: 1px solid #fff; border-radius: 50%; margin: 0 5px;}.arr-l,.arr-r { display: none; color: #fff; cursor: pointer; position: absolute; height: 40px; width: 30px; background-color: rgba(0, 0, 0, .3); line-height: 40px; text-align: center;}.arr-l { top: 50%; left: 0; transform: translateY(-50%);}.arr-r { right: 0; top: 50%; transform: translateY(-50%);}.current { background-color: #fff;}

動畫實現js文件animate.js:

function animate(obj, target, callback) { clearInterval(obj.timer); obj.timer = setInterval(function () { if (target - obj.offsetLeft > 0) { var step = Math.ceil((target - obj.offsetLeft) / 10); } else { var step = Math.floor((target - obj.offsetLeft) / 10); } if (obj.offsetLeft == target) { clearInterval(obj.timer); callback && callback(); } obj.style.left = obj.offsetLeft + step + ’px’; }, 15)}

index.js:

window.addEventListener(’load’, function () { var arrl = this.document.querySelector(’.arr-l’); var arrr = this.document.querySelector(’.arr-r’); var box = this.document.querySelector(’.box’); var boxWidth = box.offsetWidth; box.addEventListener(’mouseenter’, function () { arrl.style.display = ’block’; arrr.style.display = ’block’; clearInterval(timer); timer = null; }) box.addEventListener(’mouseleave’, function () { arrl.style.display = ’none’; arrr.style.display = ’none’; timer = setInterval(function () { arrr.click(); }, 2000); }); var ul = box.querySelector(’ul’); var ol = box.querySelector(’ol’); for (var i = 0; i < ul.children.length; i++) { var li = document.createElement(’li’); li.setAttribute(’data-index’, i); ol.appendChild(li); ol.children[0].className = ’current’; li.addEventListener(’click’, function () { for (var i = 0; i < ol.children.length; i++) { ol.children[i].className = ’’; } this.className = ’current’; var dateindex = this.getAttribute(’data-index’); num = dateindex; circle = dateindex; animate(ul, -dateindex * boxWidth); }); } var first = ul.children[0].cloneNode(true); ul.appendChild(first); var num = 0; var circle = 0; var flag = true; arrr.addEventListener(’click’, function () { if (flag) { flag = false; if (num == ul.children.length - 1) { ul.style.left = 0; num = 0; } num++; animate(ul, -num * boxWidth, function () { flag = true; }); circle++; if (circle == ol.children.length) { circle = 0; } circleChange(); } }); arrl.addEventListener(’click’, function () { if (flag) { flag = false; if (num == 0) { num = ul.children.length - 1; ul.style.left = -num * boxWidth + ’px’; } num--; animate(ul, -num * boxWidth, function () { flag = true; }); circle--; if (circle < 0) { circle = ol.children.length - 1; } circleChange(); } }); function circleChange() { for (var i = 0; i < ol.children.length; i++) { ol.children[i].className = ’’; } ol.children[circle].className = ’current’; } var timer = setInterval(function () { arrr.click(); }, 2000);})

注意事項

引用兩個js文件時,animate.js要在index.js之前引用,因為index.js中要用到animate.js里的函數。

精彩專題分享:jQuery圖片輪播 JavaScript圖片輪播 Bootstrap圖片輪播

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 液压压力机,液压折弯机,液压剪板机,模锻液压机-鲁南新力机床有限公司 | 搪玻璃冷凝器_厂家-越宏化工设备 | 贴片电容-贴片电阻-二三极管-国巨|三星|风华贴片电容代理商-深圳伟哲电子 | 山东信蓝建设有限公司官网| 深圳善跑体育产业集团有限公司_塑胶跑道_人造草坪_运动木地板 | 高压油管,液压接头,液压附件-烟台市正诚液压附件 | 专业深孔加工_东莞深孔钻加工_东莞深孔钻_东莞深孔加工_模具深孔钻加工厂-东莞市超耀实业有限公司 | 无线遥控更衣吊篮_IC卡更衣吊篮_电动更衣吊篮配件_煤矿更衣吊篮-力得电子 | 铝合金重力铸造_铝合金翻砂铸造_铝铸件厂家-东莞市铝得旺五金制品有限公司 | 膜结构_ETFE膜结构_膜结构厂家_膜结构设计-深圳市烨兴智能空间技术有限公司 | 德国BOSCH电磁阀-德国HERION电磁阀-JOUCOMATIC电磁阀|乾拓百科 | 防渗膜厂家|养殖防渗膜|水产养殖防渗膜-泰安佳路通工程材料有限公司 | 代写标书-专业代做标书-商业计划书代写「深圳卓越创兴公司」 | 菲希尔X射线测厚仪-菲希尔库伦法测厚仪-无锡骏展仪器有限责任公司 | PCB设计,PCB抄板,电路板打样,PCBA加工-深圳市宏力捷电子有限公司 | 七维官网-水性工业漆_轨道交通涂料_钢结构漆 | 世界箱包品牌十大排名,女包小众轻奢品牌推荐200元左右,男包十大奢侈品牌排行榜双肩,学生拉杆箱什么品牌好质量好 - Gouwu3.com | 防爆电机-高压防爆电机-ybx4电动机厂家-河南省南洋防爆电机有限公司 | LED投光灯-工矿灯-led路灯头-工业灯具 - 山东普瑞斯照明科技有限公司 | 冷水机,风冷冷水机,水冷冷水机,螺杆冷水机专业制造商-上海祝松机械有限公司 | 尚为传动-专业高精密蜗轮蜗杆,双导程蜗轮蜗杆,蜗轮蜗杆减速机,蜗杆减速机生产厂家 | 线材成型机,线材折弯机,线材成型机厂家,贝朗自动化设备有限公司1 | 咖啡加盟-咖啡店加盟-咖啡西餐厅加盟-塞纳左岸咖啡西餐厅官网 | 上海平衡机-单面卧式动平衡机-万向节动平衡机-圈带动平衡机厂家-上海申岢动平衡机制造有限公司 | 贴片电感_贴片功率电感_贴片绕线电感_深圳市百斯特电子有限公司 贴片电容代理-三星电容-村田电容-风华电容-国巨电容-深圳市昂洋科技有限公司 | 办公室家具公司_办公家具品牌厂家_森拉堡办公家具【官网】 | 合肥角钢_合肥槽钢_安徽镀锌管厂家-昆瑟商贸有限公司 | 机床主轴维修|刀塔维修|C轴维修-常州翔高精密机械有限公司 | 福建成考网-福建成人高考网 | pH污水传感器电极,溶解氧电极传感器-上海科蓝仪表科技有限公司 | 悬浮拼装地板_幼儿园_篮球场_悬浮拼接地板-山东悬浮拼装地板厂家 | 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 | 东莞市超赞电子科技有限公司 全系列直插/贴片铝电解电容,电解电容,电容器 | 物流公司电话|附近物流公司电话上门取货| PVC地板|PVC塑胶地板|PVC地板厂家|地板胶|防静电地板-无锡腾方装饰材料有限公司-咨询热线:4008-798-128 | 土壤养分检测仪|土壤水分|土壤紧实度测定仪|土壤墒情监测系统-土壤仪器网 | 武汉刮刮奖_刮刮卡印刷厂_为企业提供门票印刷_武汉合格证印刷_现金劵代金券印刷制作 - 武汉泽雅印刷有限公司 | 大巴租车平台承接包车,通勤班车,巴士租赁业务 - 鸿鸣巴士 | 数控车床-立式加工中心-多功能机床-小型车床-山东临沂金星机床有限公司 | 半自动预灌装机,卡式瓶灌装机,注射器灌装机,给药器灌装机,大输液灌装机,西林瓶灌装机-长沙一星制药机械有限公司 | 合肥白癜风医院_合肥治疗白癜风医院_合肥看白癜风医院哪家好_合肥华研白癜风医院 |