在 React 及 Webpack 中使用 Highcharts

实例代码及运行过程

请通过这个链接下载实例代码包:https://pan.baidu.com/s/1o7IZfiM 提取码:ktrc

下载后进入实例代码目录,执行 npm install 来安装相关依赖,并通过 npm run build 将源代码打包。

项目打包命令

打包完成后即可打开 index.html 即可看到运行结果,如下图所示:

React 中使用 Highcharts

代码说明

实例代码很简单,代码在 src\app.js,代码及注释如下:

'use strict';
var React = require('react');
var ReactDOM = require('react-dom');
// 加载 Highmaps
var Highcharts = require('highcharts/highmaps.src.js');

// 加载 proj4,用于将经纬度转换成坐标值
var proj4 = require('./proj4.js');

// require json 需要安装对应的 loader,见 webpack.config.js 的 loaders 部分
var chinaData = require('./china.json');

// 图表配置,在线代码:https://code.hcharts.cn/highmaps/M9tzGW/1
var options = {
    title: {
        text: '通过经纬度描点'
    },
    mapNavigation: {
        enabled: true,
        buttonOptions: {
            verticalAlign: 'bottom'
        }
    },
    tooltip: {
        useHTML: true,
        formatter: function() {
            return this.point.name;
        }
    },
    plotOptions: {
        series: {
            dataLabels: {
                enabled: false
            },
            marker: {
                radius: 3
            }
        }
    },
    series: [{
        // 空数据列,用于展示底图
        mapData: chinaData,
        showInLegend: false
    }, {
        type: 'mappoint',
        name: '通过经纬度描点',
        data: [{
            "x": 6763,
            "y": -6381,
            "name": "北京市",
            "color": "blue"
        }, {
            "lat": 31.2319526784,
            "lon": 121.469443249,
            "color": "green",
            "name": "上海市"
        }, {
            "lat": 30.2741702308,
            "lon": 120.1551656314,
            "color": "red",
            "name": "杭州"
        }]
    }]
};
var onRender = function() {
    // 将 proj4 挂载到 window 上,这是因为 Highmaps 内部是通过 window.proj4 来访问 proj4 的
    window.proj4 = proj4;

    // Highcharts 初始化函数,其中 chart 为 容器 id
    Highcharts.Map('chart', options);
}
var chartContainer = React.createElement('div', { id: 'chart' });
ReactDOM.render(chartContainer, document.getElementById('app'), onRender);

需要注意的事项:

1、china.json 是从 https://www.hcharts.cn/mapdata 下载的

2、由于 Highmaps 内部的代码访问 pro4j 的方式同通过 window.pro4j,所有这里在 onrender 里做了处理

var onRender = function() {
    // 将 proj4 挂载到 window 上,这是因为 Highmaps 内部是通过 window.proj4 来访问 proj4 的
    window.proj4 = proj4;
}
Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×