IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> taro小程序添加Echarts实践 -> 正文阅读

[移动开发]taro小程序添加Echarts实践

小程序需要添加简单的数据统计功能。因为对Echats比较熟悉,所以想将Echats引入到项目中,有几点注意事项,记录一下。

taro版本:3.3.2(注意一下版本信息)

官方物料仓库里面的Echarts大多不兼容最新版本taro框架,但是实现的思路都是一样的。大致说一下:

准备工作
  1. 下载Echarts官方的小程序插件echarts-for-weixin 传送门
    在这里插入图片描述

  2. 将项目中的ec-canvas文件夹复制保存

  3. 去Echarts官网定制图表(不建议全部下载,文件太大,小程序体积大需要分包) 传送门

  4. 压缩echarts.js文件(压缩方法可以自行找线上压缩网站或自行压缩,方法附后文)

  5. 替换ec-canvas文件中的echarts.js文件
    在这里插入图片描述

本地压缩方法:
npm install uglify-js -g
uglifyjs echarts.js -m -o echarts.min.js //注意:替换ec-canvas里面的文件时将echarts.min.js换回来
小程序封装图表组件(以柱状图为例)
// 柱状图
import { Component } from "react";
import { View } from "@tarojs/components";
import { getCurrentInstance } from "@tarojs/taro" //Taro3.x需要使用getCurrentInstance 获取页面DOM

import './index.scss'

function setChartData(chart){
  const defautOption = {
    xAxis: {
      type: "category",
      data: ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"],
    },
    yAxis: {
      type: "value",
    },
    series: [
      {
        data: [120, 200, 150, 80, 70, 110, 130],
        type: "bar",
        showBackground: true,
        backgroundStyle: {
          color: "rgba(220, 220, 220, 0.8)",
        },
      },
    ],
  };
  chart.setOption(defautOption);
}

export default class BarChart extends Component {
  constructor(props) {
    super(props)
    this.state = {
      ec: {
        lazyLoad: true
      }
    }
  }
  componentDidMount() {
  }

  refresh(data) {
    getCurrentInstance().page.selectComponent('#mychart-area').init((canvas, width, height) => {
      const chart = echarts.init(canvas, null, {
        width: width,
        height: height
      });
      setChartData(chart, data);
      return chart;
    });
  }

  render() {
    return (
      <View className='bar-chart'>
        <ec-canvas
          id='mychart-area'
          canvasId='mychart-area'
          ec={this.state.ec}
        />
      </View>
    );
  }
}
页面使用
import React, { Component } from 'react'
import { View } from '@tarojs/components'
import BarChart from '@/components/barChart'

import './index.scss'

export default class Index extends Component {
  constructor (props) {
    super(props)
    this.barChart = React.createRef()
    this.state = {
    }
  }

  componentWillMount () { }

  componentDidMount () {
    // 延迟调用,确保 ec-canvas 节点已存在
     setTimeout(() => {
       this.barChart.current.refresh()
     }, 100)
  }

  componentWillUnmount () { }

  componentDidShow () { }

  componentDidHide () { }

  render () {
    return (
      <View className='selfstudy-container'>
        <BarChart ref={this.barChart} />
      </View>
    )
  }
}

------------------------------------------------------至此图表引入已完成90%-------------------------------------------------------------
直接页面使用的话会报两个错误:

  1. echarts is not defined。(没有拿到ec-canvas页面实例)
    在这里插入图片描述
    解决方法:在 app 或页面配置文件中配置 usingComponents 属性。
export default {
  usingComponents: {
    // 定义需要引入的第三方组件
    // 1. key 值指定第三方组件名字,以小写开头
    // 2. value 值指定第三方组件 js 文件的相对路径
    'ec-canvas': '../../components/ec-canvas/ec-canvas'
  }
}

注意:Taro3 的组件是没有配置文件的,因此 usingComponents 必须配置在“页面”的配置文件中。

  1. t.addEventListener is not a function
    在这里插入图片描述
    解决方法:在 ec-canvas文件夹下面的wx-canvas.js文件添加代码:
export default class WxCanvas {
  constructor(ctx, canvasId, isNew, canvasNode) {
    this.ctx = ctx;
    this.canvasId = canvasId;
    this.chart = null;
    this.isNew = isNew
    if (isNew) {
      this.canvasNode = canvasNode;
    }
    else {
      this._initStyle(ctx);
    }

    // this._initCanvas(zrender, ctx);

    this._initEvent();
  }
  
  // 新增空函数,修复调用 echarts.init 时报错
  addEventListener () {}

  getContext(contextType) {
    if (contextType === '2d') {
      return this.ctx;
    }
  }
}

全文结束,感谢收看,另CSDN博客即日起开始陆续迁移到新博客地址https://ovyvo.github.io/yanblog.github.io/

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-10-19 12:00:17  更:2021-10-19 12:01:59 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 0:57:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码