JavaScript實現(xiàn)的DOM繪制柱狀圖效果示例
本文實例講述了JavaScript實現(xiàn)的DOM繪制柱狀圖效果。分享給大家供大家參考,具體如下:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>www.dbjr.com.cn JavaScript DOM繪制柱狀圖</title> <style> #chart-wrap{ width:910px; height:240px; border:solid 1px #B3B3DC; position:relative; top:40px; left:20px; } </style> </head> <body> <div id="chart-wrap"></div> <script> function renderChart(data) { var cw = document.getElementById("chart-wrap"); cw.innerHTML = ""; var max = 0; for (var index in data) { if (data[index] > max) max = data[index]; } var percent = 180 / max; var i = 0; for (var index in data) { var bar = document.createElement("div"); bar.id = index + "_" + data[index]; bar.style.height = Math.round(percent * data[index]) + "px"; bar.style.width = "40px"; bar.style.left = (i * 40) + 165 + "px"; bar.style.marginLeft = (i * 20) + "px"; bar.style.position = "absolute"; bar.style.background = "none repeat scroll 0 0 pink"; bar.style.overflow = "hidden"; bar.setAttribute("title", index + ":" + data[index]); bar.style.display = "block"; bar.style.top = 200 - Math.round(percent * data[index]) + "px"; cw.appendChild(bar); var axis = document.createElement("div"); axis.id = "axis_" + i; axis.style.width = "40px"; axis.style.left = (i * 40) + 165 + "px"; axis.style.marginLeft = (i * 20) + "px"; axis.style.textAlign = "center"; axis.style.position = "absolute"; axis.style.top = "205px"; axis.innerHTML = '<span style="font-size:12px; color:grey;"> ' + i + '</span>'; cw.appendChild(axis); i++; } for (var i = 0; i < 5; i++) { var ayis = document.createElement("div"); ayis.style.width = "30px"; ayis.style.position = "absolute"; ayis.style.top = (36 * i) + (20 - 6) + "px"; ayis.style.left = "140px"; ayis.innerHTML = '<span style="font-size:12px; color:grey;"> ' + Math.round(max - (max / 5) * i) + '</span>'; cw.appendChild(ayis); var line = document.createElement("div"); line.setAttribute("style", "width:580px; left:165px; border-top:1px dotted grey; height:1px; line-height:1px; display:block; overflow:hidden; position:absolute; "); line.style.top = (36 * i) + 20 + "px"; cw.appendChild(line); } } var data = [10,60,50,30,40,80,20,70,100,90]; renderChart(data); </script> </body> </html>
運行效果如下:
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript操作DOM技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
ElementUI table無縫循環(huán)滾動的示例代碼
這篇文章主要介紹了ElementUI table無縫循環(huán)滾動的示例代碼,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08MUI 實現(xiàn)側(cè)滑菜單及其主體部分上下滑動的方法
下面小編就為大家分享一篇MUI 實現(xiàn)側(cè)滑菜單及其主體部分上下滑動的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01JavaScript前端開發(fā)時數(shù)值運算的小技巧
這篇文章主要介紹了JavaScript前端開發(fā)時數(shù)值運算的小技巧,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07