目前在 ios 上正常运行,Android 上需要将文件放于 assets 文件夹中。这篇未完待续。。。
我这里的 react-native 版本是 0.63.4 ; react-native-webview 的版本号为: 11.0.3。
react-native-webview 的 github : react-native-webview
要使用 echart 是很容易,只需要新建一个 html 文件,这个 html 文件放到两个地方,对于 ios 来说虽拜年一个地方都可以,但值得一说的是 android ,将 html 文件放到 项目文件夹/android/app/res/main/assets/ 下即可。
我的 html 文件内容为:
<!-- eCharts.html -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<script
crossorigin="anonymous"
integrity="sha512-odXFR6jGqGLJay2LHI5hit0IEfyxJ2UexST/qvnljBPrbXMwU44CoVddZjD9EsrtS6bMOoz8lC2yU0nhyh9yyg=="
src="https://lib.baomitu.com/echarts/5.0.0/echarts.common.js"
></script>
<title>Document</title>
</head>
<body>
<div>
<h1>我现在正在测试</h1>
<div id="main" style="width: 100%; height: 300px"></div>
</div>
</body>
<script type="text/javascript">
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: 'ECharts 入门示例',
},
tooltip: {},
legend: {
data: ['销量'],
},
xAxis: {
data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子'],
},
yAxis: {},
series: [
{
name: '销量',
type: 'bar',
data: [5, 20, 36, 10, 10, 20],
},
],
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
</script>
</html>
非常简单,然后在 react-native 中这样即可:
<WebView
style={{flex: 1}}
source={Platform.select({
ios: require('./eCharts.html'),
android: {
url: 'file:///android_asset/eCharts.html',
},
})}
originWhitelist={['*']}
/>
上面都可以运行了,我的目标是都使用同一个文件,或者都维护同一份代码,在不把 html 文件放到服务器的情况下完成。