最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Web前端實現(xiàn)元素周期表

來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 20:24:12
文檔

Web前端實現(xiàn)元素周期表

Web前端實現(xiàn)元素周期表:一、什么是旭日圖旭日圖是在Excel 2016中新增的一種圖表。有些類似餅圖,餅圖的優(yōu)勢是可以顯示占比。但是餅圖只能顯示單級數(shù)據(jù)。旭日圖用來表示多層級數(shù)據(jù)的占比。旭日圖以一種分層方式顯示,非常適合用來顯示層級數(shù)據(jù)。層次結(jié)構(gòu)中每個級別的比例通過1個圓環(huán)
推薦度:
導讀Web前端實現(xiàn)元素周期表:一、什么是旭日圖旭日圖是在Excel 2016中新增的一種圖表。有些類似餅圖,餅圖的優(yōu)勢是可以顯示占比。但是餅圖只能顯示單級數(shù)據(jù)。旭日圖用來表示多層級數(shù)據(jù)的占比。旭日圖以一種分層方式顯示,非常適合用來顯示層級數(shù)據(jù)。層次結(jié)構(gòu)中每個級別的比例通過1個圓環(huán)
一、什么是旭日圖

旭日圖是在Excel 2016中新增的一種圖表。有些類似餅圖,餅圖的優(yōu)勢是可以顯示占比。但是餅圖只能顯示單級數(shù)據(jù)。旭日圖用來表示多層級數(shù)據(jù)的占比。旭日圖以一種分層方式顯示,非常適合用來顯示層級數(shù)據(jù)。層次結(jié)構(gòu)中每個級別的比例通過1個圓環(huán)表示,離原點越近代表圓環(huán)級別越高,最內(nèi)層的圓表示頂級結(jié)構(gòu),然后一層一層去看數(shù)據(jù)的占比情況。

我們通過一個簡單的示例,初步感受一下旭日圖的魅力。

季度

月份

銷量

Q1

1月份

 

29

2月份

第一周

63

第二周

54

第三周

91

第四周

78

3月份

 

49

Q2

4月份

 

66

5月份

 

110

6月份

 

42

Q3

7月份

 

19

8月份

 

73

9月份

 

109

Q4

10月份

 

32

11月份

 

112

12月份

 

99

表1 某產(chǎn)品的銷量統(tǒng)計

圖1 用旭日圖表示的銷量

通過表1我們可以看到它是一個層級數(shù)據(jù),第1級是季度,第2級是月份,第3級是周。圖1是根據(jù)表1在Excel中繪制的旭日圖。內(nèi)層顯示第1級季度,其外層的圓環(huán)顯示第2級月份,最外層圓環(huán)顯示第3級周。顯示的每個占比是根據(jù)其對應(yīng)的銷售來計算。

二、簡單示例

我們了解了旭日圖之后,在有些場景中我們就想在自己的系統(tǒng)中使用旭日圖。Wijmo中提供了JS控件可以讓我們在Web純前端使用旭日圖。如果想在.Net平臺下使用旭日圖可以了解ComponentOne中的FlexChart。通過下面一個簡單的示例,對如何使用旭日圖有一個初步的了解。

HTML文件:

1、引入Wijmo的css和js

 <!-- Styles -->
 <link href="styles/vendor/wijmo.min.css" rel="stylesheet" />
 <link href="styles/app.css" rel="stylesheet" />

 <!-- Wijmo -->
 <script src="scripts/vendor/wijmo.min.js" type="text/javascript"></script>
 <script src="scripts/vendor/wijmo.chart.min.js" type="text/javascript"></script><script src="scripts/vendor/wijmo.chart.hierarchical.min.js" type="text/javascript"> </script>

2、定義一個p

這個p用戶顯示旭日圖。

<p id="introChart"></p>

3、引入自定義的js文件

<script src="scripts/app.js"></script><script src="scripts/sunburst.js"></script>

app.js:

// 產(chǎn)生數(shù)據(jù)var app = {
 getData: function () { var data = [],
 months = [['Jan', 'Feb', 'Mar'], ['Apr', 'May', 'June'], ['Jul', 'Aug', 'Sep'], ['Oct', 'Nov', 'Dec']],
 years = [2014, 2015, 2016];

 years.forEach(function (y, i) {
 months.forEach(function (q, idx) { var quar = 'Q' + (idx + 1);
 q.forEach(function (m) {
 data.push({
 year: y.toString(),
 quarter: quar,
 month: m,
 value: Math.round(Math.random() * 100)
 });
 });
 });
 }); return data;
 },
};

創(chuàng)建了一個app類,其中包含一個getData方法,用于產(chǎn)生一個多級數(shù)據(jù)。它的級別分別是年、季度、月份。

sunburst.js:

(function(wijmo, app) { 'use strict'; // 創(chuàng)建控件
 var chart = new wijmo.chart.hierarchical.Sunburst('#introChart'); // 初始化旭日圖 chart.beginUpdate(); // 旭日圖包含的值得屬性名
 chart.binding = 'value'; // 設(shè)置層級數(shù)據(jù)中子項目的名稱,用于在旭日圖中生成子項
 chart.bindingName = ['year', 'quarter', 'month']; // 設(shè)置數(shù)據(jù)源
 chart.itemsSource = app.getData(); // 設(shè)置數(shù)據(jù)顯示的位置
 chart.dataLabel.position = wijmo.chart.PieLabelPosition.Center; // 設(shè)置數(shù)據(jù)顯示的內(nèi)容
 chart.dataLabel.content = '{name}'; // 設(shè)置選擇模式
 chart.selectionMode = 'Point';

 chart.endUpdate();
})(wijmo, app);

根據(jù)p的ID創(chuàng)建一個Sunburst對象,設(shè)置數(shù)據(jù)源以及相關(guān)屬性。數(shù)據(jù)源通過app.getData()提供。

下面是程序運行的結(jié)果。

圖2 運行結(jié)果

三、用“旭日圖”實現(xiàn)元素周期表

有了以上的知識儲備之后,我們就可以做復雜一點的實現(xiàn)。下面我們用“旭日圖”實現(xiàn)元素周期表。我們上高中的時候,都應(yīng)該學習過元素周期表,它是類似如下的一張表。這張表更多了展示了元素的信息,但是沒有很好的展示元素歸類的信息。我們現(xiàn)在用旭日圖來做它,對這點進行改善。

圖3 元素周期表

HTML文件:

和簡單示例中的類似,需要引入Wijmo相關(guān)的樣式和js文件。

1、引入自定義的js文件

<script src="scripts/DataLoader.js"></script><script src="scripts/app.js"></script>

2、定義一個p

<p id="periodic-sunburst" class="periodic-sunburst"></p>

DataLoader.js:

創(chuàng)建了一個DataLoader類,其中提供兩個方法。readFile方法讀取json文件獲得數(shù)據(jù)。isInclude 方法判斷數(shù)組中是否存在指定的元素。generateCollectionView方法中對數(shù)據(jù)進行加工處理。

var DataLoader = {};// 一級分類var METALS_TITLE = "金屬";var NON_METALS_TITLE = "非金屬";var OTHERS_TITLE = "過渡元素";// 二級分類var METAL_TYPES = '堿金屬|(zhì)堿土金屬|(zhì)過渡金屬|(zhì)鑭系元素|錒系元素|其他金屬'.split('|');var NON_METAL_TYPES = '惰性氣體|鹵素|非金屬'.split('|');var OTHER_TYPES = '準金屬|(zhì)超錒系'.split('|');

DataLoader = {

 readFile: function (filePath, callback) { var reqClient = new XMLHttpRequest();
 reqClient.onload = callback;
 reqClient.open("get", filePath, true);
 reqClient.send();
 },

 isInclude: function (arr, data) { if (arr.toString().indexOf(data) > -1) return true; else
 return false;
 },

 generateCollectionView: function (callback) {
 DataLoader.readFile('data/elements.json', function (e) { // 獲取數(shù)據(jù)
 var rawElementData = JSON.parse(this.responseText); var elementData = rawElementData['periodic-table-elements'].map(function (item) {
 item.properties.value = 1; return item.properties;
 }); var data = new wijmo.collections.CollectionView(elementData); // 利用wijmo.collections.PropertyGroupDescription 進行第一級分組
 data.groupDescriptions.push(new wijmo.collections.PropertyGroupDescription('type', function (item, prop) { if (DataLoader.isInclude(METAL_TYPES, item[prop])) { return METALS_TITLE;
 } else if (DataLoader.isInclude(NON_METAL_TYPES, item[prop])) { return NON_METALS_TITLE;
 } else { return OTHERS_TITLE;
 }
 })); // 進行第二級分組
 data.groupDescriptions.push(new wijmo.collections.PropertyGroupDescription('type', function (item, prop) { return item[prop];
 }));

 callback(data);
 });
 }
};

generateCollectionView方法中調(diào)用readFile獲得json數(shù)據(jù),之后利用Wijmo中提供的CollectionView對數(shù)據(jù)進行2級分組。第1級是金屬、非金屬、過渡元素。第2級分別是他們的子級別。第3級是元素,每個元素的Value都是1,表示元素的占比相同。

app.js:

和前邊的簡單示例相比,這里綁定的數(shù)據(jù)源是CollectionView.Groups,它是CollectionView中的第一級分組。

var mySunburst;function setSunburst(elementCollectionView) { 
 // 創(chuàng)建旭日圖控件
 mySunburst = new wijmo.chart.hierarchical.Sunburst('#periodic-sunburst'); 

 mySunburst.beginUpdate(); // 設(shè)置旭日圖的圖例不顯示
 mySunburst.legend.position = 'None'; // 設(shè)置內(nèi)圓半徑
 mySunburst.innerRadius = 0.1; // 設(shè)置選擇模式
 mySunburst.selectionMode = 'Point'; // 設(shè)置數(shù)據(jù)顯示的位置
 mySunburst.dataLabel.position = 'Center'; // 設(shè)置數(shù)據(jù)顯示的內(nèi)容
 mySunburst.dataLabel.content = '{name}'; 

 // 進行數(shù)據(jù)綁定
 mySunburst.itemsSource = elementCollectionView.groups; // 包含圖表值的屬性名
 mySunburst.binding = 'value'; // 數(shù)據(jù)項名稱
 mySunburst.bindingName = ['name', 'name', 'symbol']; 

 // 在分層數(shù)據(jù)中生成子項的屬性的名稱。
 mySunburst.childItemsPath = ['groups', 'items']; 
 mySunburst.endUpdate();

};

DataLoader.generateCollectionView(setSunburst);

運行結(jié)果:

圖4 旭日圖表示的元素周期表

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Web前端實現(xiàn)元素周期表

Web前端實現(xiàn)元素周期表:一、什么是旭日圖旭日圖是在Excel 2016中新增的一種圖表。有些類似餅圖,餅圖的優(yōu)勢是可以顯示占比。但是餅圖只能顯示單級數(shù)據(jù)。旭日圖用來表示多層級數(shù)據(jù)的占比。旭日圖以一種分層方式顯示,非常適合用來顯示層級數(shù)據(jù)。層次結(jié)構(gòu)中每個級別的比例通過1個圓環(huán)
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top