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

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

原生JS實現(xiàn)pc端輪播圖效果

瀏覽:93日期:2024-04-09 15:12:23

本文實例為大家分享了JS實現(xiàn)pc端輪播圖效果的具體代碼,供大家參考,具體內(nèi)容如下

案例:輪播圖需求

布局:ul下有很多l(xiāng)i標簽;浮動在一行;

原理:切換圖片的時候,把ul位置修改一下,給ul的父容器,設置一個 overflow:hidden;

功能需求:

序號輪播 左右按鈕的輪播 自動輪播 鼠標在輪播圖里面的時候,停止自動輪播,離開后繼續(xù)自動輪播

實現(xiàn)效果:

原生JS實現(xiàn)pc端輪播圖效果

html部分

<div id='box'> <div id='inner'> <ul id='imglist'><li> <a href='http://www.hdgsjgj.cn/bcjs/14257.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/1.jpg' alt=''></a></li><li> <a href='http://www.hdgsjgj.cn/bcjs/14257.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/2.jpg' alt=''></a></li><li> <a href='http://www.hdgsjgj.cn/bcjs/14257.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/3.jpg' alt=''></a></li><li> <a href='http://www.hdgsjgj.cn/bcjs/14257.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/4.jpg' alt=''></a></li><li> <a href='http://www.hdgsjgj.cn/bcjs/14257.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/5.jpg' alt=''></a></li><li> <a href='http://www.hdgsjgj.cn/bcjs/14257.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/6.jpg' alt=''></a></li> </ul> <div class='list'><i class='current'>1</i><i>2</i><i>3</i><i>4</i><i>5</i><i>6</i> </div> <div class='arrow'><span class='arrow-left'>&lt;</span><span class='arrow-right'>&gt;</span> </div> </div></div>

css部分

* { margin: 0; padding: 0; }ul { list-style: none; }.box { width: 730px; height: 454px; padding: 8px; border: 1px solid green; margin: 100px auto; }.inner { position: relative; overflow: hidden; height: 454px; }#imglist { width: 700%; position: absolute; left: 0; transition: left 300ms linear; }li { float: left; }.list { position: absolute; bottom: 20px; left: 50%; margin-left: -85px; }.list i { width: 20px; height: 20px; border-radius: 50%; background-color: #fff; color: #333; float: left; font-style: normal; line-height: 20px; font-size: 14px; text-align: center; margin-right: 10px; cursor: pointer; }.list i:last-child { margin-right: 0; }.list i.current { background-color: skyblue; color: #fff; }.arrow { position: absolute; width: 100%; top: 50%; margin-top: -30px; }.arrow-left, .arrow-right { width: 30px; height: 60px; position: absolute; font: 20px/60px 'consolas'; color: #fff; background-color: rgba(0, 0, 0, .3); text-align: center; cursor: pointer; }.arrow-right { right: 0; }

js部分:

// 獲取DOM var yuan = document.querySelectorAll('i'); var li = document.querySelector('ul li'); var ul = document.querySelector('ul'); var imgs = document.querySelector('#imglist'); var right = document.querySelector('.arrow-right'); var left = document.querySelector('.arrow-left'); var box = document.querySelector('.box'); window.onload = function() { //------------------------------------這里是點擊小圓圈,控制圖片的切換 //循環(huán)小圓點 注冊小圓點 for (var i = 0; i < yuan.length; i++) { //我們需要這里面的i 必須提前拿出來,要不最后i的值就是最后一個數(shù)值了 yuan[i].num = i; //注冊事件 yuan[i].onmouseover = function() {// 現(xiàn)在要循環(huán)將樣式移除for (var j = 0; j < yuan.length; j++) { yuan[j].classList.remove('current');}//這里是為了將點擊的小圓點 增加上樣式this.classList.add('current');var num = this.num;//到這里的思路就是點擊小圓點 將圖片進行移動,向左面移動,上面css做了相應的定位操作//移動的距離就是 n 乘以 一張圖片的寬度,//n 就是選擇的小圓點的 坐標-----i(num)//圖片的寬度 box.offsetWidthvar left = num * li.offsetWidth;// console.log(num, box.offsetWidth, left);imgs.style.left = `-${left}px`;//這里小原點聯(lián)動左右按鈕for (var p = 0; p < yuan.length; p++) { //清除全部樣式(小圓點) yuan[p].classList.remove('current');}//給當前的小圓點增加樣式y(tǒng)uan[num].classList.add('current');//這里這個位置比較關鍵,在上面設置完樣式之后,記得將此num賦值給全局的indexindex = this.num; } } //------------------------------------以上是點擊小圓圈,控制圖片的切換 //------------------------------------下面是開始右面輪播,控制圖片的切換 //首先定義一個全局的index,這個index的作用依舊是控制圖片的切換 var index = 0; right.onclick = function() { index++; //這里要對index做一下判斷,如果不做判斷,可以試想一下, //只要你一點擊,index就會無限的增大,增大到你“無法自拔” if (index == ul.children.length) {//如果坐標為6的話,顯示應該顯示第1張圖片,所以要復位 即index=0index = 0; } var left = index * li.offsetWidth; // console.log(index, box.offsetWidth, left); imgs.style.left = `-${left}px`; //點擊右面增加聯(lián)動小圓點的效果 for (var n = 0; n < yuan.length; n++) {//清除全部樣式(小圓點)yuan[n].classList.remove('current'); } //給當前的小圓點增加樣式 yuan[index].classList.add('current'); }; //------------------------------------以上是結(jié)束右面輪播,控制圖片的切換 //------------------------------------下面是開始左面輪播,控制圖片的切換 left.onclick = function() { index--; //這里同右點擊一樣,需要做一下判斷, console.log(index); if (index == -1) {index = ul.children.length - 1; } var left = index * li.offsetWidth; // console.log(index, box.offsetWidth, left); // console.log(left); imgs.style.left = `-${left}px`; //這個位置做的是 左面點擊聯(lián)動小圓點 for (var m = 0; m < yuan.length; m++) {//清除全部樣式(小圓點)yuan[m].classList.remove('current'); } //給當前的小圓點增加樣式 yuan[index].classList.add('current'); }; //------------------------------------上面是結(jié)束左面輪播,控制圖片的切換 //------------------------------------開始設置自動輪播 var timer = setInterval(function() { right.onclick(); }, 1000); //------------------------------------以上是自動輪播結(jié)束 //------------------------------------設置鼠標進來就停止開始 box.onmouseover = function() { clearInterval(timer); }; //------------------------------------設置鼠標進來就停止結(jié)束 //------------------------------------設置鼠標出去就停止開始 box.onmouseout = function() { timer = setInterval(function() {right.onclick(); }, 1000); }; //------------------------------------設置鼠標出去就停止結(jié)束 }

未完待續(xù),本篇文章做的PC端的處理,目前從6頁-1頁,1頁到6頁還有點小瑕疵,會及時更新上的,其他功能一切正常,歡迎大家評論

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 哈尔滨发电机,黑龙江柴油发电机组-北方星光 | 水冷式工业冷水机组_风冷式工业冷水机_水冷螺杆冷冻机组-深圳市普威机械设备有限公司 | 带式压滤机_污泥压滤机_污泥脱水机_带式过滤机_带式压滤机厂家-河南恒磊环保设备有限公司 | 打包钢带,铁皮打包带,烤蓝打包带-高密市金和金属制品厂 | 造价工程师网,考试时间查询,报名入口信息-网站首页 | 博博会2021_中国博物馆及相关产品与技术博览会【博博会】 | 菏泽商标注册_菏泽版权登记_商标申请代理_菏泽商标注册去哪里 | 厂房出租-厂房规划-食品技术-厂房设计-厂房装修-建筑施工-设备供应-设备求购-龙爪豆食品行业平台 | 软瓷_柔性面砖_软瓷砖_柔性石材_MCM软瓷厂家_湖北博悦佳软瓷 | 齿轮减速机_齿轮减速电机-VEMT蜗轮蜗杆减速机马达生产厂家瓦玛特传动瑞环机电 | 水厂自动化|污水处理中控系统|水利信息化|智慧水务|智慧农业-山东德艾自动化科技有限公司 | 聚合氯化铝价格_聚合氯化铝厂家_pac絮凝剂-唐达净水官网 | 奶茶加盟,奶茶加盟店连锁品牌-甜啦啦官网 | 上海橡胶接头_弹簧减震器_金属软接头厂家-上海淞江集团 | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-沼河浸过滤器 | 北京开源多邦科技发展有限公司官网 | 聚氨酯复合板保温板厂家_廊坊华宇创新科技有限公司 | 期货软件-专业期货分析软件下载-云智赢 | 钛板_钛管_钛棒_钛盘管-无锡市盛钛科技有限公司 | 北京中航时代-耐电压击穿试验仪厂家-电压击穿试验机 | 工作心得_读书心得_学习心得_找心得体会范文就上学道文库 | 纯化水设备-EDI-制药-实验室-二级反渗透-高纯水|超纯水设备 | 3d打印服务,3d打印汽车,三维扫描,硅胶复模,手板,快速模具,深圳市精速三维打印科技有限公司 | 金属软管_不锈钢金属软管_巩义市润达管道设备制造有限公司 | 双工位钻铣攻牙机-转换工作台钻攻中心-钻铣攻牙机一体机-浙江利硕自动化设备有限公司 | 德州网站制作 - 网站建设设计 - seo排名优化 -「两山建站」 | 健身器材-健身器材厂家专卖-上海七诚健身器材有限公司 | 北京工业设计公司-产品外观设计-产品设计公司-千策良品工业设计 北京翻译公司-专业合同翻译-医学标书翻译收费标准-慕迪灵 | 档案密集架_电动密集架_移动密集架_辽宁档案密集架-盛隆柜业厂家现货批发销售价格公道 | 洗瓶机厂家-酒瓶玻璃瓶冲瓶机-瓶子烘干机-封口旋盖压盖打塞机_青州惠联灌装机械 | 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 | 环氧铁红防锈漆_环氧漆_无溶剂环氧涂料_环氧防腐漆-华川涂料 | 浇钢砖,流钢砖_厂家价低-淄博恒森耐火材料有限公司 | 宝宝药浴-产后药浴-药浴加盟-艾裕-专注母婴调养泡浴 | 深圳装修_店面装修设计_餐厅设计_装修全包价格-尚泰装饰设计 | 酶联免疫分析仪-多管旋涡混合仪|混合器-莱普特科学仪器(北京)有限公司 | 合肥触摸一体机_触摸查询机厂家_合肥拼接屏-安徽迅博智能科技 | 振动筛,震动筛,圆形振动筛,振动筛价格,振动筛厂家-新乡巨宝机电 蒸汽热收缩机_蒸汽发生器_塑封机_包膜机_封切收缩机_热收缩包装机_真空机_全自动打包机_捆扎机_封箱机-东莞市中堡智能科技有限公司 | PCB设计,PCB抄板,电路板打样,PCBA加工-深圳市宏力捷电子有限公司 | 山东PE给水管厂家,山东双壁波纹管,山东钢带增强波纹管,山东PE穿线管,山东PE农田灌溉管,山东MPP电力保护套管-山东德诺塑业有限公司 | 宽带办理,电信宽带,移动宽带,联通宽带,电信宽带办理,移动宽带办理,联通宽带办理 |