首頁 php教程 php手册 原生JS写的幻灯片

原生JS写的幻灯片

Jun 07, 2016 am 11:39 AM

学习PHP时期,为了练习Javascript而写的幻灯片函数,个人认为还算简单使用啊,兼容性也算可以
//幻灯片<br> <br>     //该幻灯片函数只需要html页面有一个有id的div即可,将id值和图片路径数组传入即可调用,其他参数有默认值,可按需传值<br>     function slide(sid,imgs,width,height,btn_w,btn_h,interval,speed){<br> <br>         //幻灯片的属性<br>         var sid=sid;//幻灯片容器div的id值<br>         var imgs=imgs;//幻灯片图片的路径数组<br>         var width=width||800;//幻灯片的宽度,默认800px<br>         var height=height||400;//幻灯片的高度,默认400px<br>         var btn_w=btn_w||30;//幻灯片图片的宽度,默认30px<br>         var btn_h=btn_w||30;//幻灯片图片的高度,默认30px<br>         var interval=interval||3;//每张图片停留的秒数,默认3秒<br>         var speed=speed||2;//图片滑动速度的档位,默认2档,可以1档,3档<br> <br>         var images=[];//用来存放图片对象的数组<br>         var imgQty=imgs.length;//图片的数量<br>         var curImg=0;//幻灯片当前不滑动图片的数组索引<br>         var nextImg=1;//幻灯片当前滑动的图片的数组索引<br> <br>         var btns=[];//用来存放幻灯片按钮对象的数组<br> <br>         var timer1=null;//用来储存幻灯片播放的超时调用方法<br>         var timer2=null;//用来存储滑动动画的超时调用方法<br> <br>         var isDone = false; //是否滑动完成<br>         <br>         //设置幻灯片的元素的方法<br>         function setElements(){    <br> <br>             //幻灯片容器<br>             var container=document.getElementById(sid);//通过幻灯片容器id得到幻灯片的div元素对象<br>             var btnRow=document.createElement('ul');//创建按钮容器ul<br>             container.appendChild(btnRow);//将按钮容器ul插入幻灯片容器中<br>             <br>             //为幻灯片容器添加事件<br>             container.onmouseover=function(){//鼠标划入停止播放<br>                 clearTimeout(timer1);<br>             }<br>             container.onmouseout=function(){//鼠标划出3秒后继续播放<br>                 timer1=setTimeout(play,3000);<br>             }<br> <br>             //图片和按钮<br>             for(var i=0;i<img qty alt="原生JS写的幻灯片" ></imgqty>                 //创建图片<br>                 images[i]=document.createElement('img');<br>                 //为图片添加src属性<br>                 images[i].src=imgs[i];<br> <br>                 //将图片节点添加到容器中<br>                 container.appendChild(images[i]);<br> <br>                 //创建按钮<br>                 btns[i]=document.createElement('li');//li标签作为图片按钮传入btns数组中<br>                 btns[i].innerHTML=i+1;//给按钮填入序号<br>                 btnRow.appendChild(btns[i]);//将按钮节点添加到按钮栏中<br> <br>                 //为按钮添加事件<br>                 btns[i].onmouseover = switchImg;<br>                 btns[i].onclick = switchImg;<br> <br>             }<br>             <br>             //为幻灯片的元素添加css属性<br>             var head=document.getElementsByTagName('head')[0];//获取头标签<br>             var style=document.createElement('style');//创建style标签<br>             head.appendChild(style);//将style标签插入头标签中<br>             //设置css字符串<br>             var css="#slide{position:relative;width:800px;height:400px;overflow:hidden;}ul{position:absolute;right:20px;bottom:10px;z-index:9;}img{width:800px;height:400px;left:0px;top:0px;position:absolute;}li{width:30px;height:30px;margin-right:10px;float:left;background:#ccc;list-style:none;text-align:center;line-height:30px;border-radius:50%;opacity:0.8}";<br>             //css样式兼容性设计<br>             try{<br>                 style.appendChild(document.createTextNode(css));//非IE<br>             }catch(e){<br>                 style.styleSheet.cssText=css;//IE<br>             }<br> <br>             //第一次加载默认的图片层级和滑动图片的位置<br>             images[0].style.zIndex=1;//播放开始让第一幅图片为不滑动图片,层级为1<br>             images[1].style.zIndex=2;//播放开始让第二幅图片为滑动图片,层级为2<br>             images[1].style.left=width+'px';//第二幅图的位置调整到容器的右侧准备滑动<br>         <br>         }<br> <br>         //将幻灯片的元素插入页面<br>         setElements();<br> <br> <br>         //幻灯片的方法<br> <br>         //切换图片的方法<br>         function switchImg(){<br> <br>             //触发该事件的按钮的索引<br>             var btnIndex = this.innerHTML - 1;<br> <br>             //滑动完成并且触发不同的按钮的事件才会执行变换<br>             if (isDone && btnIndex != curImg) {<br> <br>                 clearTimeout(timer2);//停止之前的图片滑动<br>                 //将滑动图片立即转换为当前不滑动图片<br>                 images[curImg].style.left='0px';<br>                 images[curImg].style.zIndex=1;<br>                 //将滑动图片对应的按钮立即转换为浅色<br>                 btns[nextImg].style.background='#ccc';<br>                 btns[nextImg].style.color='#000';<br>                 //将滑动图片的数组索引更改为当前按钮对应的图片的数组索引<br>                 nextImg=this.innerHTML-1;<br>                 // //将要滑动的图片移动到容器右侧,层级设为最高,准备滑动<br>                 images[nextImg].style.left=width+'px';<br>                 images[nextImg].style.zIndex=2;<br>                 //立即滑动<br>                 move();<br>             }<br>                         <br>         }<br> <br>         //让图片完整的滑动一次的方法<br>         function move(){<br>             //滑动开始<br>             isDone = false;<br>             //将上一张滑动图片的样式和下一张滑动图片的样式做一下改变<br>             btns[curImg].style.background='#ccc';<br>             btns[curImg].style.color='#000';<br>             btns[nextImg].style.background='#333';<br>             btns[nextImg].style.color='#fff';<br> <br>             if(parseInt(images[nextImg].style.left) > 0){//判断滑动图片的left是否达到0位置<br>                 images[nextImg].style.left=Math.floor((parseInt(images[nextImg].style.left)-(parseInt(images[nextImg].style.left)-0)/(30/speed)))+'px';//没到达则每次滑动剩下路程的25分之一<br>                 timer2=setTimeout(move,10);//超时调用slide,用递归加setTimeout模仿setInterval<br>             }else{//滑动图片的left到达0位置<br>                 clearTimeout(timer2);//销毁滑动的延时调用方法<br>                 //所有图片的层级重置为0<br>                 for (var i = 0; i                      images[i].style.zIndex = 0;<br>                 }<br>                 curImg = nextImg;//将滑动完的图片的数组索引赋给不滑动图片的数组索引变量<br>                 nextImg == (imgQty - 1) ? nextImg = 0 : nextImg ++;//判断滑动完的图片的是否最后一张,是则赋为0,否则加1<br>                 //重新设置新一轮的不滑动图片和滑动图片图片的定位和层级属性<br>                 images[curImg].style.left='0px';<br>                 images[curImg].style.zIndex=1;<br>                 images[nextImg].style.left=width+'px';<br>                 images[nextImg].style.zIndex=2;    <br>                 //滑动完成<br>                 isDone = true;                <br>             }<br>         }<br> <br>         //循环播放的方法<br>         function play(){<br>             move();<br>             timer1=setTimeout(play,interval*1000);//停留三秒钟<br>         }<br>         //立即播放<br>         play();            <br>     }

AD:真正免费,域名+虚机+企业邮箱=0元

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

了解Python編程的入門級程式碼範例 了解Python編程的入門級程式碼範例 Jan 04, 2024 am 10:50 AM

了解Python程式設計的入門程式碼範例Python是一種簡單易學,功能強大的程式語言。對於初學者來說,了解Python程式設計的入門級程式碼範例是非常重要的。本文將為您提供一些具體的程式碼範例,幫助您快速入門。列印HelloWorldprint("HelloWorld")這是Python中最簡單的程式碼範例。 print()函數用於將指定的內容輸出

PHP 變數的實際應用:10 個實際使用範例 PHP 變數的實際應用:10 個實際使用範例 Feb 19, 2024 pm 03:00 PM

PHP變數儲存程式運行期間的值,對於建立動態且互動的WEB應用程式至關重要。本文將深入探討php變量,並透過10個真實的範例展示它們的實際應用。 1.儲存使用者輸入$username=$_POST["username"];$passWord=$_POST["password"];此範例從表單提交中提取使用者名稱和密碼,並將其儲存在變數中以供進一步處理。 2.設定配置值$database_host="localhost";$database_username="username";$database_pa

Go語言程式設計實例:Web開發中的程式碼範例 Go語言程式設計實例:Web開發中的程式碼範例 Mar 04, 2024 pm 04:54 PM

《Go語言程式設計實例:Web開發中的程式碼範例》隨著網路的快速發展,Web開發已成為各行業中不可或缺的一部分。作為一門功能強大且效能優越的程式語言,Go語言在Web開發中越來越受到開發者們的青睞。本文將透過具體的程式碼範例,介紹如何利用Go語言進行Web開發,讓讀者更能理解並運用Go語言來建立自己的Web應用。 1.簡單的HTTP伺服器首先,讓我們從一個

Java實作簡單的冒泡排序程式碼 Java實作簡單的冒泡排序程式碼 Jan 30, 2024 am 09:34 AM

Java冒泡排序最簡單的程式碼範例冒泡排序是一種常見的排序演算法,它的基本想法是透過相鄰元素的比較和交換來將待排序序列逐步調整為有序序列。以下是一個簡單的Java程式碼範例,示範如何實作冒泡排序:publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

從入門到精通:Go語言中常用資料結構的程式碼實現 從入門到精通:Go語言中常用資料結構的程式碼實現 Mar 04, 2024 pm 03:09 PM

標題:從入門到精通:Go語言中常用資料結構的程式碼實作資料結構在程式設計中起著至關重要的作用,它是程式設計的基礎。在Go語言中,有許多常用的資料結構,掌握這些資料結構的實作方式對於成為優秀的程式設計師至關重要。本文將介紹Go語言中常用的資料結構,並給出對應的程式碼範例,幫助讀者從入門到精通這些資料結構。 1.數組(Array)數組是一種基本的資料結構,是一組相同類型

華為雲端邊緣運算對接指南:Java程式碼範例快速實作接口 華為雲端邊緣運算對接指南:Java程式碼範例快速實作接口 Jul 05, 2023 pm 09:57 PM

華為雲端邊緣運算對接指南:Java程式碼範例快速實現介面隨著物聯網技術的快速發展和邊緣運算的興起,越來越多的企業開始關注邊緣運算的應用。華為雲端提供了邊緣運算服務,為企業提供了高可靠的運算資源和便利的開發環境,使得邊緣運算應用更容易實現。本文將介紹如何透過Java程式碼快速實現華為雲端邊緣運算的介面。首先,我們需要準備好開發環境。確保你已經安裝了Java開發工具包(

如何使用PHP編寫庫存管理系統中的庫存分倉管理功能代碼 如何使用PHP編寫庫存管理系統中的庫存分倉管理功能代碼 Aug 06, 2023 pm 04:49 PM

如何使用PHP編寫庫存管理系統中的庫存分倉管理功能碼庫存管理是許多企業中不可或缺的一部分。對於擁有多個倉庫的企業來說,庫存分倉管理功能尤其重要。透過合理管理和追蹤庫存,企業可以實現不同倉庫之間的庫存調撥,優化營運成本,改善協同效率。本文將介紹如何使用PHP編寫庫存分倉管理功能的程式碼,並為您提供相關的程式碼範例。一、建立資料庫在開始編寫庫存分倉管理功能的程式碼之

指導與範例:學習Java選擇排序演算法的實現 指導與範例:學習Java選擇排序演算法的實現 Feb 18, 2024 am 10:52 AM

Java選擇排序法程式碼編寫指南及範例選擇排序是一種簡單直觀的排序演算法,其想法是每次從未排序的元素中選擇最小(或最大)的元素進行交換,直到所有元素排序完成。本文將提供選擇排序的程式碼編寫指南,並附上具體的Java範例程式碼。演算法原理選擇排序的基本原理是將待排序數組分為已排序和未排序兩部分,每次從未排序部分選擇最小(或最大)的元素,將其放到已排序部分的末尾。重複上述

See all articles