• 技术文章 >web前端 >js教程

    用Vue.js 和 Chart.js如何制作很炫的图表

    巴扎黑巴扎黑2017-04-15 09:05:32原创2084

    深入学习 chart.js 的选项来制作漂亮的图表。交互式图表可以给你的数据可视化提供很酷的展示方式。但是大多数开箱即用的解决方案用默认的选项并不能做出很绚丽的图表。

    这篇文章中,我会教你如何自定义 chart.js 选项来制作很酷的图表。

    ⚡ Quick Start

    我们需要:

    使用 vue-cli 来搭基本架构,希望你已经安装好了。我们使用 vue-chart.js 来作为 chart.js 的打包器。

    vue init webpack awesome-charts

    然后到工程目录中安装依赖:

    cd awesome-charts && yarn install

    添加 vue-chartjs:

    yarn add vue-chartjs -S

    第一个图表

    现在我们来创建第一个折现表。

    touch src/components/LineChart.js && subl .

    现在需要从 vue-chartjs 中引入折线表的基表,创建组件。

    mount() 函数中使用我们准备好的数据和选项来调用 renderChart()方法。

        import {Line} from 'vue-chartjs'
        
        export default Line.extend({
          mounted () {
        
            this.renderChart({
              labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July'],
              datasets: [
                {
                  label: 'Data One',
                  backgroundColor: '#FC2525',
                  data: [40, 39, 10, 40, 39, 80, 40]
                },{
                  label: 'Data Two',
                  backgroundColor: '#05CBE1',
                  data: [60, 55, 32, 10, 2, 12, 53]
                }
              ]
            }, {responsive: true, maintainAspectRatio: false})
        
          }
        })

    代码中,使用了一些实例数据和可选参数传递给 chart.js 的数据对象,并且设置 responsive:true,使得图表会充满外层容器。

    之所以可以使用 renderChart() 方法是因为我们继承了 BaseChart,这个方法和一些属性都是在 BaseChart 中定义的。

    运行 & 测试

    ok,现在从 App.vue 中把 Hello.vue 删掉,并且引入我们的图表:

        <template>
          <p id="app">
            <p class="container">
              <p class="Chart__list">
                <p class="Chart">
                  <h2>Linechart</h2>
                  <line-example></line-example>
                </p>
              </p>
            </p>
          </p>
        </template>
        
        <script>
        import LineExample from './components/LineChart.js'
        export default {
          name: 'app',
          components: {
            LineExample
          }
        }
        </script>
        
        <style>
        #app {
          font-family: 'Avenir', Helvetica, Arial, sans-serif;
          -webkit-font-smoothing: antialiased;
          -moz-osx-font-smoothing: grayscale;
          text-align: center;
          color: #2c3e50;
          margin-top: 60px;
        }
        .container {
          max-width: 800px;
          margin:  0 auto;
        }
        </style>
        CopyRaw

    在终端中运行 dev 脚本,就可以看到图表了。

    yarn run dev

    把我变得更漂亮

    现在该做些美化工作了

    以上就是用Vue.js 和 Chart.js如何制作很炫的图表的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:JavaScript数据结构之二叉查找树的定义与表示方法详解 下一篇:理解Javascript中的“+”运算符
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 深析webpack的打包流程和原理• 深入了解模块打包工具webpack• JavaScript学习之使用const声明常量• JavaScript和ECMAScript之间的关系• 聊聊如何使用package.json对依赖包进行版本管理
    1/1

    PHP中文网