<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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
        當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

        使用D3.js制作表格方法介紹

        來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 20:14:22
        文檔

        使用D3.js制作表格方法介紹

        使用D3.js制作表格方法介紹:D3是目前最流行的JavaScript可視化圖表庫之一,D3的圖表類型非常豐富,并且支持SVG格式,因此應(yīng)用十分廣泛,也有很多圖表插件基于D3開發(fā),比如MetricsGraphics.js,在D3上構(gòu)建的數(shù)據(jù)圖表非常強(qiáng)大。D3是用于數(shù)據(jù)可視化的Javascript庫。使用SVG,
        推薦度:
        導(dǎo)讀使用D3.js制作表格方法介紹:D3是目前最流行的JavaScript可視化圖表庫之一,D3的圖表類型非常豐富,并且支持SVG格式,因此應(yīng)用十分廣泛,也有很多圖表插件基于D3開發(fā),比如MetricsGraphics.js,在D3上構(gòu)建的數(shù)據(jù)圖表非常強(qiáng)大。D3是用于數(shù)據(jù)可視化的Javascript庫。使用SVG,
        D3是目前最流行的JavaScript可視化圖表庫之一,D3的圖表類型非常豐富,并且支持SVG格式,因此應(yīng)用十分廣泛,也有很多圖表插件基于D3開發(fā),比如MetricsGraphics.js,在D3上構(gòu)建的數(shù)據(jù)圖表非常強(qiáng)大。

        D3是用于數(shù)據(jù)可視化的Javascript庫。使用SVG,Canvas和HTML。結(jié)合強(qiáng)大的可視化技術(shù)和數(shù)據(jù)驅(qū)動(dòng)的DOM操作方法。

        D3與JQuery的區(qū)別 D3是數(shù)據(jù)驅(qū)動(dòng)的,JQuery不是:我們使用JQuery直接操縱元素;但是使用D3
        時(shí)我們需要通過D3專有的data(),enter()和exit()方法提供數(shù)據(jù)和回調(diào),然后D3操作元素。 D3通常用于數(shù)據(jù)可視化;JQuery用于創(chuàng)建Web應(yīng)用。D3有很多數(shù)據(jù)可視化擴(kuò)展;JQuery有很多Web應(yīng)用插件。兩者都是Javascript DOM操作庫,提供CSS選擇器和流暢的API。

        What is the difference between D3 and JQuery?

        最常用的方法

        d3.select(selector):選擇第一個(gè)匹配selector的元素。如果沒有匹配的元素,返回一個(gè)空的選擇(但不是null或undefined)。

        d3.selectAll(selector):與select()不同的是,會(huì)選擇所有匹配的元素。

        selection.append(type):如果指定的type是一個(gè)字符串,則將這個(gè)type(標(biāo)簽名稱)作為新元素附加到每個(gè)選定元素的最后一個(gè)子元素。

        selection.attr(name, [value]):value確定時(shí),將selection中名為name的屬性值設(shè)置成value。value可以為常量或者方法。如果value沒有給出,返回selection中第一個(gè)非空元素的name屬性當(dāng)前值。

        selection.data([data[,key]]):將數(shù)據(jù)和元素綁定起來,并返回一個(gè)新的selection。

        selection.enter():返回enter selection。此時(shí)DOM元素少于對(duì)應(yīng)的數(shù)據(jù)。用于添加缺少的DOM元素。比如:

        如果body是空的,上面的代碼就會(huì)根據(jù)數(shù)據(jù)創(chuàng)建新的p元素,然后添加到body元素中,并將文本內(nèi)容設(shè)置為對(duì)應(yīng)的數(shù)字。頁面結(jié)果如下:

         <p>4</p>
         <p>8</p>
         <p>15</p>
         <p>16</p>
         <p>23</p>
         <p>42</p>

        selection.exit():返回exit selection。此時(shí)DOM元素多于對(duì)應(yīng)的數(shù)據(jù)。用于移除多余的DOM元素。比如,基于上面的例子,我們要更新數(shù)據(jù):

        p = p.data([1, 2, 4, 8, 16, 32], function(d) { return d; });

        因?yàn)榇藭r(shí)指定了key方法(用于指定數(shù)據(jù)和元素匹配的順序等),并且數(shù)據(jù)[4,8,16]匹配已經(jīng)存在的元素,所以u(píng)pdate selection只包含3個(gè)p元素。我們可以使用enter selection添加3個(gè)新元素:

        p.enter().append("p").text(function(d) { return d; });

        然后,還需要移除不需要的元素[15, 23, 42]:

        p.exit().remove();

        頁面結(jié)果:

         <p>1</p>
         <p>2</p>
         <p>4</p>
         <p>8</p>
         <p>16</p>
         <p>32</p>

        制作柱狀圖


        柱狀圖示例

        使用D3的時(shí)候,要對(duì)SVG的結(jié)構(gòu)有一個(gè)了解。要繪出什么圖形,需要用到什么標(biāo)簽,標(biāo)簽需要定義什么屬性。
        比如,制作一個(gè)柱狀圖,主要是XY坐標(biāo)軸和柱形。XY軸用到line標(biāo)簽繪制直線,以及text標(biāo)簽顯示刻度的文字。柱形用到rect標(biāo)簽繪制長方形,那如果要帶圓角的長方形,我們可以設(shè)置rect標(biāo)簽的rx或ry屬性,如果要定義長方形的位置,需要設(shè)置x和y屬性等。就這樣,一部分一部分的組合到一起成為一張圖。

        以下的內(nèi)容是基于D3 3.x 的API,有些接口跟D3 4.0是不同的。
        D3 3.x API Reference
        D3 4.0 API Reference

        根部的svg

        D3繪圖首先要?jiǎng)?chuàng)建一個(gè)svg元素并定義寬高等屬性:

        坐標(biāo)軸
        制作坐標(biāo)軸首先需要用到D3的比例尺。用到方法 axis.scale([scale]) ,設(shè)置坐標(biāo)軸的比例尺,或者返回當(dāng)前的比例尺。比例尺分為:

        定量比例尺:連續(xù)的數(shù)據(jù),比如數(shù)字。時(shí)間比例尺:數(shù)據(jù)是時(shí)間。序數(shù)比例尺:離散的數(shù)據(jù),比如名稱,類別等。

        比如我們要制作一個(gè)有時(shí)間刻度的X軸和一個(gè)數(shù)字刻度的Y軸,就可以使用時(shí)間比例尺和定量比例尺,或者更具體的說,線性比例尺。

        d3.scale.linear():創(chuàng)建一個(gè)線性比例尺。 d3.time.scale():創(chuàng)建一個(gè)時(shí)間比例尺??潭群涂潭雀袷脚渲脼楸镜貢r(shí)間。

        確定比例尺之后還需要設(shè)置輸入域和輸出范圍。比如一個(gè)x軸的比例尺為:

        最小日期和最大日期都是Date對(duì)象。然后設(shè)置X坐標(biāo)軸的比例尺并創(chuàng)建它:

        ticks的參數(shù)類型取決于對(duì)應(yīng)的比例尺的類型,這里傳的參數(shù)是時(shí)間間隔,也就是說刻度與刻度之間是相隔一天的。
        tickFormat則讓我們可以自定義刻度的文字格式。

        值得一說的是,如果數(shù)據(jù)中對(duì)應(yīng)X軸的數(shù)據(jù)是字符串,比如‘2017-08-12'。那綁定到頁面上的數(shù)據(jù)是需要被處理的。D3提供解析日期的接口以及日期格式化的接口。

        format.parse(string):把一個(gè)字符串string解析為一個(gè)日期。 d3.time.format(specifier):根據(jù)給定的specifier創(chuàng)建一個(gè)當(dāng)?shù)貢r(shí)間格式化。

        比如:

        最后,在svg元素中添加坐標(biāo)軸:

        selection.call(function[, arguments…])方法調(diào)用指定的方法一次,并把selection跟隨參數(shù)一起傳遞到方法中。

        柱狀圖中的長方形
        具體步驟:將數(shù)據(jù)跟頁面元素綁定,并創(chuàng)建所需要的頁面元素,具體設(shè)置每個(gè)頁面元素的樣式位置,以及事件監(jiān)聽等。

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

        文檔

        使用D3.js制作表格方法介紹

        使用D3.js制作表格方法介紹:D3是目前最流行的JavaScript可視化圖表庫之一,D3的圖表類型非常豐富,并且支持SVG格式,因此應(yīng)用十分廣泛,也有很多圖表插件基于D3開發(fā),比如MetricsGraphics.js,在D3上構(gòu)建的數(shù)據(jù)圖表非常強(qiáng)大。D3是用于數(shù)據(jù)可視化的Javascript庫。使用SVG,
        推薦度:
        標(biāo)簽: 方法 使用 介紹
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产婷婷高清在线观看免费| a级毛片免费播放| 三年片在线观看免费观看高清电影| 亚洲精品乱码久久久久久中文字幕 | 免费91麻豆精品国产自产在线观看| 国产综合精品久久亚洲| 中文字幕视频免费在线观看| 亚洲精品亚洲人成人网| 无码av免费一区二区三区试看| 久久亚洲AV午夜福利精品一区 | 亚洲人成电影福利在线播放 | 无码人妻精品中文字幕免费| 亚洲AV成人精品网站在线播放| 外国成人网在线观看免费视频| 亚洲视频精品在线观看| 无码国产精品一区二区免费 | 国产麻豆一精品一AV一免费| 亚洲综合久久综合激情久久| 国产乱码免费卡1卡二卡3卡| 亚洲av无码成人影院一区 | 亚洲色偷偷狠狠综合网| 在线免费观看h片| 亚洲精品午夜久久久伊人| 在线a人片天堂免费观看高清| 免费大片av手机看片高清| 亚洲热妇无码AV在线播放| 亚洲w码欧洲s码免费| 亚洲国产精华液2020| 亚洲熟女少妇一区二区| 一二三四在线播放免费观看中文版视频 | 亚洲第一区视频在线观看| 成全高清视频免费观看| 一级黄色免费大片| 亚洲视频免费在线看| 在线免费观看a级片| 最新亚洲成av人免费看| 亚洲ts人妖网站| 国产成人精品亚洲精品| 青娱乐免费在线视频| a毛片成人免费全部播放| 亚洲第一精品电影网|