使用 Google Charts 绘制烛台图时传递多维数组的正确方法

聖光之護
发布: 2025-08-28 23:52:18
原创
887人浏览过

使用 google charts 绘制烛台图时传递多维数组的正确方法

本文档旨在帮助开发者在使用 Google Charts 绘制烛台图时,正确地将多维数组数据传递给 google.visualization.arrayToDataTable 函数。通过示例代码和详细解释,避免 "Last domain does not have enough data columns (missing 3)" 错误,并确保图表能够正确渲染。

正确传递多维数组数据

在使用 google.visualization.arrayToDataTable 函数时,需要注意其参数的格式。该函数期望接收一个二维数组作为输入,其中每一行代表图表中的一行数据。如果你的数据已经是一个二维数组,那么不需要将其包裹在额外的数组中。

错误示例:

var data = google.visualization.arrayToDataTable([chartdata],true); // 错误:chartdata 已经被包裹在额外的数组中
登录后复制

正确示例:

var data = google.visualization.arrayToDataTable(chartdata,true); // 正确:直接传递 chartdata
登录后复制

在这个例子中,chartdata 变量本身就是一个二维数组,包含了烛台图所需的数据(日期、开盘价、收盘价、最高价、最低价)。因此,直接将 chartdata 传递给 google.visualization.arrayToDataTable 函数即可。

四维时代AI开放平台
四维时代AI开放平台

四维时代AI开放平台

四维时代AI开放平台 66
查看详情 四维时代AI开放平台

完整代码示例

以下是修改后的完整 JavaScript 代码,用于从 HTML 表格中提取数据并绘制烛台图:

$(document).ready(function(){
    $(document).on("click", "button", function(){

        var parenthis = this.parentElement;
        var tr = parenthis.querySelectorAll('.data');

        var chartdata = [];

        for(var x=0 ; x < tr.length ; x++){

            var subdata = [];
            var array=['date_','open','close','high','low'];

            for(var y=0 ; y < array.length ; y++){

                var class_table = parenthis.querySelectorAll("[class=" + CSS.escape(array[y]) + "]"); 

                if(y==0){
                    subdata.push(class_table[x].innerHTML);
                }
                else if(y==4){
                    subdata.push(parseFloat(class_table[x].innerHTML));
                    chartdata.push(subdata);
                }
                else{
                    subdata.push(parseFloat(class_table[x].innerHTML))
                }

            };                    
        };

        // candlestick chart 
        google.charts.load('current', {'packages':['corechart']});
        google.charts.setOnLoadCallback(drawChart);

        function drawChart(){

            // [[str,num/float,num/float,num/float,num/float],]
            var data = google.visualization.arrayToDataTable(chartdata,true); // 修改这里

            var options = {
            legend:'none',
            };

            var chart = new google.visualization.CandlestickChart(document.getElementById('chart'));
            chart.draw(data, options);
        };      
    })        
});
登录后复制

HTML 代码保持不变:

<div >
    <div>
        <button>OK</button>
        <table id="haha">
            <thead>
                <tr>
                    <td>date</td>
                    <td>open</td>
                    <td>close</td>
                    <td>high</td>
                    <td>low</td>
                    <td>change</td>
                </tr>
            </thead>
            <tr class="data">
                <td class="date_">2022-05-25 12:00</td>
                <td class="open">12</td>
                <td class="close">864</td>
                <td class="high">889</td>
                <td class="low">76</td>
                <td class="change">66</td>
            </tr>
            <tr class="data">
                <td class="date_">2022-05-25 13:00</td>
                <td class="open">765</td>
                <td class="close">45</td>
                <td class="high">97</td>
                <td class="low">82</td>
                <td class="change">613</td>
            </tr>
        </table>
    </div>
</div>
<div id="chart" style="width: 900px; height: 500px;"></div>
登录后复制

总结

正确地将多维数组传递给 google.visualization.arrayToDataTable 函数是使用 Google Charts 绘制图表的关键一步。 确保数据格式与函数期望的格式一致,可以避免常见的错误,并确保图表能够正确渲染。 在本例中,直接传递二维数组 chartdata 即可解决问题。

以上就是使用 Google Charts 绘制烛台图时传递多维数组的正确方法的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号