native-echarts 问题总结
一.当width 和 height 设置的不对的时候,会出现边框线如图所示:

解决办法:Echarts/index.js文件中
<WebView
ref="chart"
scrollEnabled = {false}
injectedJavaScript = {renderChart(this.props)}
style={{
height: this.props.height || 400,
backgroundColor: 'rgba(0,0,0,0)', // ***********add by yourself*******************
}}
automaticallyAdjustContentInsets={true}
source={require('./tpl.html')}
/>
二 折线区域图设置为渐变色,去掉节点,变成平滑
series: [{
name: 'Clouds',
type: 'line',
// 变成平滑线
smooth:true,
//这句就是去掉点的
symbol:'none',
data: [5, 7, 13, 20, 30],
// 设置为填充样式,把这句去掉的话,即为普通的折线图
areaStyle: {
normal: {
color: {
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0, color: 'rgba(6,81,222, 0.5)' // 100% 处的颜色
},
{
offset: 0.5, color: 'rgba(6,81,222, 0.2)' // 50% 处的颜色
},
{
offset: 1, color: 'rgba(253,253,253,0.17)' // 0% 处的颜色
},
],
}
}
},
// 设置为渐变色, 此处设置的是针对网页的
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(
0, 0, 0, 1,
[
{offset: 0, color: 'red'},
{offset: 0.5, color: 'pink'},
{offset: 1, color: '#ddd'}
]
)
}
}
}]
三 环图某一个项,设置为渐变色
data:[
{value:335, name:'正面消息', selected: true, itemStyle: normal: {
color: {
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0, color: 'rgba(250,79,125,1)' // 100% 处的颜色
},
{
offset: 1, color: 'rgba(244,39,71,1)' // 0% 处的颜色
},
]
},
}},
{value:180, name:'负面消息', itemStyle: {normal: 'green'}},
]
四 android 打包后,所有的图表显示不出来
1./node_modules/native-echarts/src/components/Echarts/ 目录下的tpl.html 拷贝一份
2./android/app/src/main 创建 assets文件夹
3.把第一步拷贝的文件放到第二步创建的assets文件夹下
4.进入Echarts文件(/node_modules/native-echarts/src/components/Echarts/index) 把WebView的source改为
source={{uri: 'file:///android_asset/tpl.html'}}
五 修改图例颜色
react-native-echarts 修改图例颜色首先要修改itemStyle的颜色
六 解决频繁刷新
进入Echarts文件(/node_modules/native-echarts/src/components/Echarts/index)
shouldComponentUpdate(nextProps, nextState) {
const thisProps = this.props || {}
nextProps = nextProps || {}
if (Object.keys(thisProps).length !== Object.keys(nextProps).length) {
return true
}
for (const key in nextProps) {
if (JSON.stringify(thisProps[key]) != JSON.stringify(nextProps[key])) {
// console.log('props', key, thisProps[key], nextProps[key])
return true
}
}
return false
}
componentWillReceiveProps(nextProps) {
if(nextProps.option !== this.props.option) {
// 解决数据改变时页面闪烁的问题
this.refs.chart.injectJavaScript(renderChart(nextProps,false))
}
}
修改WebView的属性injectedJavaScript
injectedJavaScript = {renderChart(this.props,true)}
进入renderChart文件(/node_modules/native-echarts/src/components/Echarts/renderChart)
export default function renderChart(props, isFirst) {
const height = props.height || 400;
if (isFirst) {
return `
document.getElementById('main').style.height = "${height}px";
myChart = echarts.init(document.getElementById('main'));
myChart.setOption(${toString(props.option)});
`
} else {
return `
document.getElementById('main').style.height = "${height}px";
myChart.setOption(${toString(props.option)});
`
}
七 折线图节点添加点击事件
进入renderChart文件(/node_modules/native-echarts/src/components/Echarts/renderChart)
添加
myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});
添加后
if (isFirst) {
return `
document.getElementById('main').style.height = "${height}px";
myChart = echarts.init(document.getElementById('main'));
myChart.setOption(${toString(props.option)});
myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});
`
} else {
return `
document.getElementById('main').style.height = "${height}px";
myChart.setOption(${toString(props.option)});
myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});
`
}
进入Echart文件(/node_modules/native-echarts/src/components/Echarts/index)
WebView添加属性
onMessage={this.onMessage}
添加事件
// 添加点击事件
onMessage = (event) => {
if (this.props.onNodePress) {
console.log(event.nativeEvent)
this.props.onNodePress(event.nativeEvent.data)
}
}
最终修改后
进入Echarts文件(/node_modules/native-echarts/src/components/Echarts/index)
import React, { Component } from 'react';
import { WebView, View, StyleSheet,Platform } from 'react-native';
import renderChart from './renderChart';
import renderChartNoFirst from './renderChart'
import echarts from './echarts.min';
export default class App extends Component {
// 预防过渡渲染
shouldComponentUpdate(nextProps, nextState) {
const thisProps = this.props || {}
nextProps = nextProps || {}
if (Object.keys(thisProps).length !== Object.keys(nextProps).length) {
return true
}
for (const key in nextProps) {
if (JSON.stringify(thisProps[key]) != JSON.stringify(nextProps[key])) {
// console.log('props', key, thisProps[key], nextProps[key])
return true
}
}
return false
}
componentWillReceiveProps(nextProps) {
if(nextProps.option !== this.props.option) {
// 解决数据改变时页面闪烁的问题
this.refs.chart.injectJavaScript(renderChart(nextProps,false))
}
}
// 添加点击事件
onMessage = (event) => {
if (this.props.onNodePress) {
console.log(event.nativeEvent)
this.props.onNodePress(event.nativeEvent.data)
}
}
render() {
if (Platform.OS == 'android'){
return (
<View style={{flex: 1, height: this.props.height || 400,}}>
<WebView
ref="chart"
scrollEnabled = {false}
injectedJavaScript = {renderChart(this.props,true)}
onMessage={this.onMessage}
style={{
height: this.props.height || 400,
backgroundColor: 'rgba(0,0,0,0)',
}}
//source={require('./tpl.html')}
// 解决安卓打包不显示问题
source={{uri: 'file:///android_asset/tpl.html'}}
/>
</View>
);
}else{
return (
<View style={{flex: 1, height: this.props.height || 400,}}>
<WebView
ref="chart"
scrollEnabled = {false}
scalesPageToFit={false}
injectedJavaScript = {renderChart(this.props,true)}
onMessage={this.onMessage}
style={{
height: this.props.height || 400,
backgroundColor: 'rgba(0,0,0,0)',
}}
source={require('./tpl.html')}
/>
</View>
);
}
}
}
进入renderChart文件(/node_modules/native-echarts/src/components/Echarts/renderChart)
import echarts from './echarts.min';
import toString from '../../util/toString';
var myChart = null;
export default function renderChart(props, isFirst) {
const height = props.height || 400;
if (isFirst) {
return `
document.getElementById('main').style.height = "${height}px";
myChart = echarts.init(document.getElementById('main'));
myChart.setOption(${toString(props.option)});
myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});
`
} else {
return `
document.getElementById('main').style.height = "${height}px";
myChart.setOption(${toString(props.option)});
myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});
`
}
}
使用
onChartNodePress(data) {
console.log(data)
this.setState({
selectedNodeIndex: data,
})
}
<Echarts option={option} width={width} height={177}
onNodePress={(data) => this.onChartNodePress(data)}
/>
android 双击图表会缩小
/node_modules/native-echarts/src/components/Echarts/index.js
Line 24
scalesPageToFit={false}
替换为
scalesPageToFit={Platform.OS === 'android'}
native-echarts 问题总结的更多相关文章
- react native中使用echarts
开发平台:mac pro node版本:v8.11.2 npm版本:6.4.1 react-native版本:0.57.8 native-echarts版本:^0.5.0 目标平台:android端收 ...
- react native使用百度echarts显示图表
echarts是百度推出的免费开源的图表组件,功能丰富,涵盖各行业图表.公司项目做h5项目用了不少,最近公司翻新h5页面,用react-native改造,来达到增强用户体验效果的目的.项目中遇到了一些 ...
- React native 之 图标库ECharts的使用
github地址:https://github.com/somonus/react-native-echarts 官网:https://www.echartsjs.com/zh/tutorial.ht ...
- 使用Echarts实现动态曲线图表
最近做的一个在线气象观测网站要实现一个需求:使用图表展示最近五天温湿度等气象要素的曲线变化 具体效果参考:http://www.weatherobserve.com/showInfoIndex.jsp ...
- 【微信小程序项目实践总结】30分钟从陌生到熟悉 web app 、native app、hybrid app比较 30分钟ES6从陌生到熟悉 【原创】浅谈内存泄露 HTML5 五子棋 - JS/Canvas 游戏 meta 详解,html5 meta 标签日常设置 C#中回滚TransactionScope的使用方法和原理
[微信小程序项目实践总结]30分钟从陌生到熟悉 前言 我们之前对小程序做了基本学习: 1. 微信小程序开发07-列表页面怎么做 2. 微信小程序开发06-一个业务页面的完成 3. 微信小程序开发05- ...
- ECharts(中国地图篇)的使用
代码html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <me ...
- 【React自制全家桶】一、Webstrom+React+Ant Design+echarts搭建react项目
前言 一.React是Facebook推出的一个前端框架,之前被用于著名的社交媒体Instagram中,后来由于取得了不错的反响,于是Facebook决定将其开源.出身名门的React也不负众望,成功 ...
- 基于React Native的跨三端应用架构实践
作者|陈子涵 编辑|覃云 “一次编写, 到处运行”(Write once, run anywhere ) 是很多前端团队孜孜以求的目标.实现这个目标,不但能以最快的速度,将应用推广到各个渠道,而且还能 ...
- 📝 没 2 年 React Native 开发经验,你都遇不到这些坑
如果你喜欢我的文章,希望点赞 收藏 评论 三连支持一下,谢谢你,这对我真的很重要! React Native 开发时,如果只是写些简单的页面,基本上按着官方文档 reactnative.dev就能写出 ...
- 一起来玩echarts系列(一)------箱线图的分析与绘制
一.箱线图 Box-plot 箱线图一般被用作显示数据分散情况.具体是计算一组数据的中位数.25%分位数.75%分位数.上边界.下边界,来将数据从大到小排列,直观展示数据整体的分布情况. 大部分正常数 ...
随机推荐
- IQueryable.Where中动态生成多个并或筛选Expression<Func<T, bool>>
直接上图
- 自定义new和delete
#include "stdafx.h" #include <stdlib.h> #include <malloc.h> #include <iostr ...
- 洛谷P3324 [SDOI2015]星际战争 题解
题目链接: https://www.luogu.org/problemnew/show/P3324 分析: 因为本题的时间点较多,不能枚举,但发现有单调性,于是二分答案,二分使用的时间TTT 每个攻击 ...
- Spring+SpringMVC+mybatis maven pom文件
pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w ...
- Java多线程笔记总结
1.线程的三种创建方式 对比三种方式: 通过继承Thread类实现 通过实现Runnable接口 实现Callable接口 第1种方式无法继承其他类,第2,3种可以继承其他类: 第2,3种方式多线程可 ...
- JDBC秒变C3P0连接池——再加连接解耦
从JDBC连接到C3P0数据库连接池 在Java开发中,使用JDBC操作数据库的四个步骤如下: ①加载数据库驱动程序(Class.forName("数据库驱动类");) ② ...
- drf初体验
快速开始 安装 pip install djangorestframework 创建django项目 django-admin startproject mydrf 创建APP cd mydrf py ...
- Netty源码解析---服务端启动
Netty源码解析---服务端启动 一个简单的服务端代码: public class SimpleServer { public static void main(String[] args) { N ...
- win10+Anaconda3+CUDA9.0+CUDNN7.1+TensorFlow-gpu1.9+Pycharm
想在win10上运行下YOLO的例子,要先配置环境,折腾了两天,终于好了,整理下自己觉得有用且正确的流程. win10+Anaconda3+CUDA9.0+CUDNN7.1+TensorFlow1.9 ...
- C#文件下载流程
private bool DownloadPicture(string picUrl, string savePath, int timeOut) { bool ...