思路:使用javascript定時(shí)器函數(shù)setTimeout()每隔一定的毫秒間隔數(shù)執(zhí)行動(dòng)作,在執(zhí)行的動(dòng)作中循環(huán)替換圖片的src屬性。樹立演示如下:
十載的新會(huì)網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都全網(wǎng)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整新會(huì)建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。成都創(chuàng)新互聯(lián)公司從事“新會(huì)網(wǎng)站設(shè)計(jì)”,“新會(huì)網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
1、HTML結(jié)構(gòu)
img?src="1.png"?id="test"
2、javascript代碼
function?change(n){
if(n5)?n=1;??//?一共5張圖片,所以循環(huán)替換
document.getElementById("test").setAttribute("src",?n+".png");
n++;
setTimeout("change("+n+")",1000);
}
window.onload?=?function(){
setTimeout("change(1)",?1000);
}
3、效果演示
JS圖形、圖標(biāo)庫推薦:
1. JS Charts
JS Charts 是個(gè)基于JavaScript的圖表生成器,不需要任何編碼。JS Charts 非常容易使用,只要用戶使用客戶端腳本(比如,在 web 瀏覽器中執(zhí)行)。它不需要多余的插件和服務(wù)器模塊,只需要下載 JS Charts 的腳本,準(zhǔn)備好 XML,JSON 或者 JavaScript 數(shù)組數(shù)據(jù)。
2. Canvasjs
CanvasJS 是個(gè)易用的 HTML5 JavaScript 圖表庫,基于 Canvas 元素。Graphs 可以通過設(shè)備渲染,包括 iPhone,iPad,Android,Windows Phone,Microsoft Surface,Desktops 等等。它允許用戶創(chuàng)建適用于所有設(shè)備,不影響 web 應(yīng)用程序的功能和可維護(hù)性的富儀表盤。CanvcasJS 有著非常漂亮的主題和超過傳統(tǒng)的 Flash 和 SVG 圖表 10x 倍以上的速度——生成輕量級(jí),漂亮和響應(yīng)式的儀表圖。
3. Chart.js
Chart.js 是個(gè)簡單的,面向?qū)ο蟮目蛻舳藞D形庫,用戶可以用 6 中不同的方式來可視化數(shù)據(jù)。每個(gè)方式都是動(dòng)畫效果的,完全自定義,而且看起來非常好看,即使在 retina 顯示。它使用 HTML5 canvas 元素,支持所有現(xiàn)代瀏覽器,并且支持 IE7/8。
4. Aristochart
Aristochart 是個(gè)高度自定義,靈活的折線 Canvas 圖表庫,允許用戶集中精力在圖表的審美方面,后臺(tái)工作做得非常好。Aristochart 有個(gè)持續(xù)進(jìn)步的社區(qū),提供許多不斷增長的主題給用戶選擇。
5. xCharts
xCharts 是一個(gè)使用 D3.js 來構(gòu)建漂亮的可定制的數(shù)據(jù)驅(qū)動(dòng)的 JavaScript圖表庫,他使用HTML,CSS,SVG實(shí)現(xiàn)圖表,xCharts 被設(shè)計(jì)為一個(gè)動(dòng)態(tài)的、流暢的、開放的和可定制化的庫。
6. BonsaiJS
BonsaiJS 是個(gè)輕量級(jí)的 JavaScript圖形庫,提供直觀的圖形 API 和 SVG 渲染器。主要特性包括:架構(gòu)分離的運(yùn)行器和渲染器;iFrame,Worker 和 Node 運(yùn)行上下文;形狀,路徑,Assets(音頻,圖像,字體,subMovies),Keyframe 和常規(guī)動(dòng)畫,等等。支持現(xiàn)代化瀏覽器: Safari, Chrome 和 Firefox。
7. Sigma.js
Sigma.js 是個(gè)免費(fèi)開源的 JavaScript圖形庫,使用 HTML5 canvas 元素。它的設(shè)計(jì)是特別為了在 web 界面分享交互式網(wǎng)絡(luò) Map 和動(dòng)態(tài)展示網(wǎng)絡(luò)數(shù)據(jù)庫。
8. Morris.js
Morris.js 是個(gè)輕量級(jí)的 JavaScript庫,使用 jQuery 和 Raphaenuml 來繪制時(shí)序圖。 Morris.js 生命周期是從代碼驅(qū)動(dòng) howmanyleft.co.uk 圖表開始的。它支持的瀏覽器有: IE6+, Safari/Chrome/Firefox, iOS 3+ 和 Android 3+。它的公共 API 非常的小,只有一個(gè)函數(shù): Morris.Line(選項(xiàng)),包括了許多配置選項(xiàng)。
9. Paper.js
Paper.js 是一個(gè)開源的向量圖形腳本框架,基于 HTML5Canvas 開發(fā)。提供清晰的場景圖、DOM和大量強(qiáng)大的功能用來創(chuàng)建各種向量圖和貝塞爾曲線。
10. AmCharts
AmCharts 是個(gè)高級(jí)圖表庫,適用于所有數(shù)據(jù)的可視化。AmCharts 包括: Column, Bar, Line, Area, Step, Step without risers, Smoothed line, Candlestick, OHLC, Pie/Donut, Radar/ Polar, XY/Scatter/Bubble, Bullet, Funnel/Pyramid 等等。
11. Smoothie Charts
Smoothie Charts是個(gè)極小的圖表庫,專為實(shí)時(shí)流媒體數(shù)據(jù)設(shè)計(jì)的。Joe Walnes 想展示 WebSocket推動(dòng)的實(shí)時(shí)的流數(shù)據(jù)。雖然很多圖表庫允許用戶動(dòng)態(tài)更新數(shù)據(jù),但是沒有一個(gè)是可以優(yōu)化源源不斷的流數(shù)據(jù)。
12. Dygraphs
Dygraphs 是個(gè)快速,靈活,開源的 JavaScript 圖表庫。它允許用戶展示和解析密集的數(shù)據(jù)集??梢愿吡列枰獜?qiáng)調(diào)的數(shù)據(jù)集??梢允褂檬髽?biāo)點(diǎn)擊或者用鼠標(biāo)拖動(dòng)來縮放圖表;可以修改數(shù)值或者點(diǎn)擊條目來調(diào)整平均周期。
13. Grafico
Grafico 是 Grafico 是一個(gè)基于 Rapha?l 和 Prototype.js 構(gòu)建的 JavaScript 圖表庫,提供了各種圖表類型。這些漂亮的圖表,有利于傳遞他們的信息。
14. Highchart JS
Highcharts JS 是一個(gè)制作圖表的純 Javascript類庫,主要特性如下:兼容性:兼容當(dāng)今所有的瀏覽器,包括 iPhone、IE 和火狐等等;對(duì)個(gè)人用戶完全免 費(fèi);純JS,無BS;支持大部分的圖表類型:直線圖,曲線圖、區(qū)域圖、區(qū)域曲線圖、柱狀圖、餅裝圖、散布圖;跨語言:不管是 PHP、Asp.net 還是 Java 都可以使用。
15. Flotr
Flotr 是一個(gè)基于 Prototype 開發(fā)的 JavaScript繪圖工具。支持圖例,鼠標(biāo)跟蹤,圖片區(qū)域選擇,圖片縮放,添加事件鉤子(event hook),通過CSS設(shè)置樣式等。
16. Flot
Flot 是受 Plotr 和 PlotKit 的 啟發(fā),Ole Laursen 基于 jquery 開發(fā)了一個(gè)圖表繪制(WEB Chart)插件并命名為 flot。 flot 是個(gè)純 JavaSript 庫,專注于簡單的使用方式,迷人的外觀和交互式特性。支持的瀏覽器有: Internet Explorer 6+, Chrome, Firefox 2+, Safari 3+ and Opera 9.5+。
17. jFreeChart
JFreeChart 主要用來各種各樣的圖表,這些圖表包括:餅圖、柱狀圖(普通柱狀圖以及堆棧柱狀圖)、線圖、區(qū)域圖、分布圖、混合圖、甘特圖以及一些儀表盤等等。JFreeChart 項(xiàng)目歷史悠久,而且有大量的開發(fā)者在維護(hù)。
18. Plotkit
PlotKit 是一個(gè)純 JavaScript 繪圖工具包。它支持 HTML Canvas 和 Adobe SVG。有著很完整的文檔,方便用戶使用。
19. Planetary.js
Planetary.js 是個(gè)令人稱奇的創(chuàng)建交互式 web 地球儀的 JavaScript庫。它使用 D3 和 TopoJSON 來解析和渲染地理信息。Planetary.js 使用基于插件的架構(gòu),甚至默認(rèn)自身就是個(gè)插件!這使得 Planetary.js 非常靈活,而且它是允許用戶完全自定義,包括顏色,大小,rotation 等等。更重要的是,用戶可以在任意位置使用自定義的顏色和大小來顯示動(dòng)畫“pings”;它還支持鼠標(biāo)拖動(dòng)和縮放,100% 免費(fèi)和開源。
20. Ember Charts
Ember Charts 是個(gè)圖表庫,使用 Ember.js 和 d3.js 框架構(gòu)建的。它包括時(shí)間線,條形圖,餅圖和散點(diǎn)圖,非常容易擴(kuò)展和修改。這些圖表組件都是開箱即用的,在圖表交互和演示方面應(yīng)用的很好。
21. Sparky
Sparky 是個(gè)免費(fèi)的 JavaScript 波形圖庫,依賴于 Rapha?l ,非常容易使用。支持多個(gè)圖表類型(折線,條形,area),折線和區(qū)域圖可以有多個(gè)顏色選擇。
22. Envision.js
Envision.js 是個(gè) JavaScript 庫,用來簡化,快速創(chuàng)建交互式的 HTML5 可視化圖表。它包括兩個(gè)圖表類型:時(shí)序圖和 Finance ,提供 API 給開發(fā)者,用戶可以直接自定義創(chuàng)建圖表。這個(gè)庫氏基于 Flotr2 和 HTML5 Canvas 的。它與框架無關(guān),依賴于幾個(gè)小的 JavaScript 庫。
23. Dc.js
dc.js 是個(gè) JavaScript 圖表庫,有著原生的 crossfilter, 支持和允許高效展示大型多維數(shù)據(jù)集(基于 crossfilter 的示例);圖表使用 dc.js 渲染,是使用原生數(shù)據(jù)驅(qū)動(dòng),所以能得到用戶的實(shí)時(shí)反饋;dc.js 最大的亮點(diǎn)在于能提供一個(gè)簡單而強(qiáng)大的 JavaScript 庫,能進(jìn)行數(shù)據(jù)可視化和分析;不僅支持桌面瀏覽器還支持移動(dòng)端。
24. ElyCharts
Elycharts 是一個(gè)易于使用的,可定制的 JavaScript圖表繪制組件。這個(gè)組件可用于繪制大部分常用的圖表類型包括:line, column, are, bar, pie, sparklines and combinations。它支持多種交互式功能包括:鼠標(biāo)跟蹤、事件處理、利用各種動(dòng)畫高亮顯示選擇中的區(qū)域,Tooltip,HTML錨點(diǎn)等。可以動(dòng) 態(tài)修改數(shù)據(jù),并以漂亮的動(dòng)畫效果展示圖表中的變化。圖表利用SVG/VML技術(shù)生成,基于jQuery + Rapha?l開發(fā)。
25. AwesomeChartJS
AwesomeChartJS Awesome Chart JS 是一個(gè) JavaScript生成圖表的類庫,它利用了 HTML5 的 canvas 標(biāo)簽來創(chuàng)建統(tǒng)計(jì)圖表。此類庫就是為了減輕開發(fā)者的工作量,使用它只需書寫幾行代碼便能生成漂亮的圖表。
26. Arbor.js
Arbor.js 是一個(gè)利用 Web Works 和 jQuery創(chuàng)建的可視化圖形庫,它為圖形組織和屏幕刷新處理提供了一個(gè)高效的、力導(dǎo)向的布局算法。
27. CanvasXpress
canvasXpress 是一個(gè)基于HTML5 canvas標(biāo)簽實(shí)現(xiàn)的 JavaScript圖表類庫,它能夠支持線性圖、柱形圖、餅圖和熱點(diǎn)圖等多種常見的圖表類型。它所生成的圖表交互性很強(qiáng),鼠標(biāo)放 上去時(shí)會(huì)動(dòng)態(tài)顯示值。除此之外,它也具有相當(dāng)高的可定制性,可設(shè)置圖表的文字、顏色和要顯示/隱藏的元素等。當(dāng)然更重要的一點(diǎn)是,雖然它使用了 HTML5,但是依然支持IE6瀏覽器。
28. JSXGraph
JSXGraph 是一個(gè)支持各種瀏覽器的交互式幾何圖庫繪制。JSXGraph 使用 SVG 和 VML。
29. Rickshaw
Rickshaw 是一個(gè)用于繪制時(shí)序圖的簡單 jS 庫,基于 Mike Bostock’s delightful D3 庫構(gòu)建。
30. rGraph
RGraph 是基于HTML5 canvas標(biāo)簽的HTML5 canvas圖形庫,支持 20 種不同的可視化類型。使用 canvas 標(biāo)簽,RGraph 創(chuàng)建“HTML5 圖表”,意味著更快的 web 頁面加載和更少的 web 服務(wù)器加載。這能幫助減小 web 頁面的大小,低能耗和更快的瀏覽速度。
31. Fusion Chart
FusionCharts Suite XT 是個(gè)專業(yè)的 JavaScript圖表庫,能創(chuàng)建任何類型的圖表。它創(chuàng)建的圖表都是可以進(jìn)行完全自定義的,標(biāo)簽,字體,邊界等等,都可以進(jìn)行修改。它有很強(qiáng)的交互功能,有許多信息提示,可 點(diǎn)擊的 legend 關(guān)鍵字,還有 dril-down,縮放/滾動(dòng) 和單擊打印圖表功能。
32. Graph Dracula
Dracula 是用一系列的工具來顯示和布局互動(dòng)圖表,包括各種相關(guān)的算法。它只是純 JavaScript 和 SVG ,并無 Flash,Java,其他插件。它非常容易使用,用戶可以很簡單的自定義任意的元素。
33. Bluff
Bluff 是個(gè) JavaScript 的 Ruby 的 Gruff graphing library端口。它支持所有 Gruff 的特性,但是有著最小的依賴。用戶只需要運(yùn)行一個(gè)第三方腳本: JS.Class 副本(壓縮后只有 2.6kB ) 和 Google 的 ExCanvas 副本,用來支持 IE 中的 canvas。這兩個(gè)腳本在 Bluff 中都有下載。Bluff 自身壓縮后大小大概有 11KB 。
34. Pizza Pie Chart
Pizza Pie Charts 是個(gè)響應(yīng)式餅圖圖表,基于 Adobe Snap SVG 框架,通過 HTML 標(biāo)記和 CSS 來替代 JavaScript 對(duì)象,更容易集成各種先進(jìn)的技術(shù)。
35. jGraph
HTML5 圖表組件,完全支持l IE 6-8 和觸屏設(shè)備。 JGraph 自2001年來就一直提供最先進(jìn)的圖表軟件組件,是第一個(gè)流行的 JGraph Swing 庫。然后在 2005 年走在時(shí)代的前沿開發(fā) mxGraph。
當(dāng)然不是,js大著呢……輪播圖才到哪。。。
學(xué)好js要把基礎(chǔ)打牢,高級(jí)程序設(shè)計(jì)和權(quán)威指南要帶著看,不管能不能吃透徹,但最起碼得看過至少一遍吧。
想練習(xí)就做項(xiàng)目,項(xiàng)目驅(qū)動(dòng)比自己自學(xué)可能會(huì)更有力。然后你可以繼續(xù)向下學(xué)習(xí)ES6、前端自動(dòng)化、基本的node知識(shí)、webpack、一些前端框架等等(當(dāng)然這些都是你對(duì)HTML,css很熟練的情況下,這些基礎(chǔ)一定要牢,不然一個(gè)最簡單的切圖都不會(huì),那肯定不是個(gè)合格的前端。。。),一起進(jìn)步一起學(xué)習(xí),共勉~
這個(gè)不是js的問題,是css的問題。
你用兩個(gè)div嵌套,一個(gè)在外面固定死寬度,高度,然后溢出隱藏。
里面一個(gè)div寬度設(shè)置9999px,就可以放很多張圖片了。。。。
$('#reset').click(function(){//重置
$('img').css({"left":"0","top":"100px"});
});
$('#left').click(function(){//左
$('img').animate({
left:"-=10",
},500);
});
$('#right').click(function(){//右
$('img').animate({
left:"+=10",
},500);
});
$('#up').click(function(){//上
$('img').animate({
top:"-=10",
},500);
});
$('#down').click(function(){//下
$('img').animate({
top:"+=10",
},500);
});
給圖加上想對(duì)定位