日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Anychart圖表系列一:入門介紹

系統 2336 0

在項目中使用Anychart圖表已經有8個月有余,對Anychart整體也有了一定的了解,產品升級的空閑期,分享一點Anychart圖表的使用經驗。

?

  • 前言

Anychart是一款基于Flash/HTML5(最新的6.0x版本開始支持HTML5)進行圖形渲染的圖表組件,圖數據采用了XML格式進行解析,主要提供Javascript方法調用的形式來將圖形渲染到web頁面。

這是一款商業收費產品,使用未授權的產品時,圖表背景會有“Anychart”字樣的水印。

官網地址: http://www.anychart.com/home/

幫助文檔地址: http://anychart.com/products/anychart/docs/users-guide/index.html?QuickStart.html

XML格式標簽文檔說明: http://anychart.com/products/anychart/docs/xmlReference/index.html

擼主大多數Anychart技術都是從幫助文檔中學習的,雖然英語只有四級,但是看起來感覺壓力也不大,某些單詞不懂就谷歌翻譯。

?

  • HelloWorld

如何創建自己的第一個圖表在官網文檔中已經有詳細說明,鏈接在 這里 ,下面我再結合例子簡單說明一下。

?

首先下載圖表的相關文件,主要包括一個或兩個js、多個swf文件。

Anychart的js文件有兩個:AnyChart.js和AnyChartHTML5.js,前者是圖表必備js文件,后者是如果你需要支持HTML5時才需要的文件,所以有的時候可用可不用。

Anychart的swf文件也有多個,用得最多的是AnyChart.swf和Preloader.swf,前者包含了所有的圖數據;后者是一個優化性能的文件,在IE高版本瀏覽器下效果明顯,如果圖很多并在一頁顯示不完,它可以達到延遲加載的效果,即優先顯示第一頁的圖。同時呢,如果你下載的是官方給的鏈接,你會發現除了以上兩個swf還會有Chart.swf、Pie.swf、Funnel.swf等等文件,這些文件都比Anychart.swf小,其實他們的作用是如果你只想用某一類的圖并且為了加載更快,可以單一選擇某一種swf來渲染。

?

然后準備一個html文件和xml文件。因為Anychart可以在web頁面中顯示,所以我們需要準備一個html文件,并且在里面編寫圖形生成代碼,最后訪問這個html即可看到效果。而XML前面已經說了,Anychart是通過解析XML數據來生成圖形的,也就是說你希望圖形是以餅狀還是柱狀還是別的圖形顯示,已經你希望顯示的數據是什么,是否顯示標題,是否顯示動畫效果等等配置都是通過XML來說明的。

?

下面看一個簡單的XML例子,通過plot_type來定義圖是水平還是豎直顯示;通過<series>的type來說明是什么類型的圖;<point>是一條數據,下面有5條就表示圖表會出5條柱子;<point>的name有很多種術語解釋,我通常稱之為“指標”,而屬性y則是指標對應的數據值,我通常稱之為“指標值”。

?

      <anychart>
  <charts>
    <chart plot_type="CategorizedHorizontal">
      <data>
        <series name="Year 2003" type="Bar">
          <point name = "Department Stores" y="637166"/>
          <point name = "Discount Stores" y="721630"/>
          <point name = "Men's/Women's Specialty Stores" y="148662"/>
          <point name = "Juvenile Specialty Stores" y="78662"/>
          <point name = "All other outlets" y="90000"/>
        </series>
      </data>
      <chart_settings>
        <title>
          <text>Sales of ACME Corp.</text>
        </title>
      </chart_settings>
    </chart>
  </charts>
</anychart>
    

上面這段XML,個人認為是是最最簡單的XML了,在項目中你可能會遇到比這復雜百倍的XML,但是不要氣餒,后續我會教大家如何讓圖表“組件化”。?

?

?

下面是一段HTML代碼,這段代碼告訴你如何調用Anychart并且生成圖形,首先需要new Anychart(swf url)的形式生成Anychart對象,然后設置圖形的高度和寬度,通過setXMLFile(xml url)指定XML數據文件,在通過writ方法即可顯示圖形了。

      <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <title>Sample AnyChart Flash Chart</title>
    <script type="text/javascript" language="javascript" src="./js/AnyChart.js"></script>
  </head>
  <body>
    <script type="text/javascript" language="javascript">
      //<![CDATA[
		var chart = new AnyChart('./swf/AnyChart.swf');
		chart.width = 600;
		chart.height = 300;
		chart.setXMLFile('./anychart.xml');
		chart.write();
	  //]]>
    </script>
  </body>
</html>
    

?

下面看最后的圖形效果


Anychart圖表系列一:入門介紹
?

至此,一個最簡單的Anychart圖表生成了,如果想看到圖的效果,可以在官網下載該例子( 點這里

?

針對上面的HTML呢,做一些擴展,有些用戶不希望通過chart.write方法出圖,有些用戶不希望傳入XML文件地址,而是直接傳一段XML字符串來生成圖,其實這個功能Anychart都提供了,并且也是我一直很推薦的寫法。

下面這段代碼介紹了如何解決上面的需求:通過new Anychart(swf url,preloader swf) 傳入preloader.swf地址來提高大數據量圖表加載速度,通過setXMLData方法可以傳入XML字符串,通過write(html id)來將圖表渲染到指定HTML標簽內。Anychart圖表高寬度支持傳入px像素值,也支持百分百比的形式,需要注意的是圖表的高寬度依賴于自己父容器(html標簽)的高寬度,即如果你的父容器本身很小,那么圖表像素設置再高也不會有效果的。

?

      <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
	<meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
	<title>sample-single-series-column-chart</title>
	<style type="text/css">
		html, body, #chartContainer {
			width: 100%;
			height: 100%;
			padding: 0;
			margin: 0;
		}
	</style>
	<script type="text/javascript" language="JavaScript" src="js/AnyChart.js"></script>
	<script type="text/javascript" language="JavaScript">
	    var chart = new AnyChart('swf/AnyChart.swf', 'swf/Preloader.swf');
	    chart.width = "100%";
        chart.height = "100%";
        chart.setXMLData("<anychart>......</anychart>");
	    chart.write("chartContainer");
	</script>
</head>
<body>
<div id="chartContainer"></div>
</body>
</html>

    

?

  • 總結

生成圖表分為以下幾個簡單的步驟:

①環境搭建:準備Anychart必備文件(Javascript和swf)

②準備XML數據

③web頁面編寫代碼,調用Anychart對象生成圖形

?

第一篇說得很簡單,后續我將從多方面一步步介紹如何靈活使用Anychart。

Anychart圖表系列一:入門介紹


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 石河子市| 宁晋县| 新乡县| 陆丰市| 搜索| 密山市| 建昌县| 洱源县| 宁乡县| 南岸区| 兴化市| 化德县| 牡丹江市| 盐津县| 凤城市| 平陆县| 沾益县| 西林县| 柘城县| 普安县| 安溪县| 盐城市| 吴川市| 开阳县| 称多县| 通许县| 剑川县| 遵义市| 丁青县| 澎湖县| 灵武市| 和静县| 甘孜县| 田阳县| 济源市| 秀山| 云梦县| 获嘉县| 易门县| 五大连池市| 靖安县|