基于Ionic3实现选项卡切换并重新加载echarts


Posted in Javascript onSeptember 24, 2020

要求

选项卡每切换一次,就加载对应的一个echarts 图,要有一开始的动画效果

效果如下:

基于Ionic3实现选项卡切换并重新加载echarts

注意点

1、echarts要想每次都能重新加载,需要移除"_echarts_instance_"属性,否则一切换选项卡,就再也加载不出来了

2、在ts 中获取html 页面元素,不能写在构造方法里,应该写在ionViewDidEnter()方法里

3、选项卡<ion-segment> 不要搭配[ngSwitch] 的方式,因为这种情况下,只能获取当前选项卡中的元素,未选中的选项卡里的元素获取不到,在第2步骤ionViewDidEnter() 方法里自然也是获取不到。应当搭配(ionChange)使用方式

4、不能直接将chart作为全局变量,这样的话第二次加载就没有动画效果了

献上代码

html文件

<ion-header>
 <ion-navbar>
  <ion-title>区域</ion-title>
 </ion-navbar>

</ion-header>

<ion-content padding>

  <ion-segment [(ngModel)]="choice" (ionChange)="segmentChanged($event)">
   <ion-segment-button value="choice1">
    省份增速排名
   </ion-segment-button>
   <ion-segment-button value="choice2">
    市州增速排名
   </ion-segment-button>
   <ion-segment-button value="choice3">
    全省走势
   </ion-segment-button>
   <ion-segment-button value="choice4">
    市州占比
   </ion-segment-button>
  </ion-segment>

  <div id="chartContainer" style="width: 100%; height: 300px;"></div>

</ion-content>

ts文件

import {Component} from '@angular/core';
import * as echarts from 'echarts';

@Component({
 selector: 'page-data-area',
 templateUrl: 'area.html'
})
export class DataAreaPage {
 choice: string = "choice1";
 ec: any = echarts;
 chartContainer: any;

 constructor() {
 }

 clickChart1() {
  const chart1 = this.ec.init(this.chartContainer);
  chart1.setOption({
   series: {
    type: 'pie',
    data: [{
     name: 'A',
     value: 10
    }, {
     name: 'B',
     value: 20
    }, {
     name: 'C',
     value: 30
    }, {
     name: 'D',
     value: 40
    }]
   }
  }, true);
  this.chartContainer.removeAttribute("_echarts_instance_");
 }

 clickChart2() {
  const chart2 = this.ec.init(this.chartContainer);
  chart2.setOption({
   series: {
    type: 'pie',
    data: [{
     name: 'A',
     value: 10
    }, {
     name: 'B',
     value: 20
    }, {
     name: 'C',
     value: 30
    }]
   }
  }, true);
  this.chartContainer.removeAttribute("_echarts_instance_");
 }

 clickChart3() {
  const chart3 = this.ec.init(this.chartContainer);
  chart3.setOption({
   series: {
    type: 'pie',
    data: [{
     name: 'A',
     value: 10
    }, {
     name: 'B',
     value: 20
    }, {
     name: 'C',
     value: 30
    }, {
     name: 'D',
     value: 40
    }, {
     name: 'E',
     value: 50
    }]
   }
  }, true);
  this.chartContainer.removeAttribute("_echarts_instance_");
 }

 clickChart4() {
  const chart4 = this.ec.init(this.chartContainer);
  chart4.setOption({
   series: {
    type: 'pie',
    data: [{
     name: 'A',
     value: 10
    }, {
     name: 'B',
     value: 20
    }, {
     name: 'C',
     value: 30
    }, {
     name: 'D',
     value: 40
    }, {
     name: 'E',
     value: 50
    }, {
     name: 'F',
     value: 60
    }]
   }
  }, true);
  this.chartContainer.removeAttribute("_echarts_instance_");
 }

 segmentChanged(e) {
  if (e.value == "choice1") {
   this.clickChart1();
  } else if (e.value == "choice2") {
   this.clickChart2();
  } else if (e.value == "choice3") {
   this.clickChart3();
  } else if (e.value == "choice4") {
   this.clickChart4();
  }
 }

 ionViewDidEnter() {
  this.chartContainer = document.getElementById('chartContainer');
  this.clickChart1();
 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
在视频前插入广告
Nov 20 Javascript
用正则获取指定路径文件的名称
Feb 27 Javascript
一次$.getJSON不执行的简单记录
Jul 19 Javascript
微信小程序(六):列表上拉加载下拉刷新示例
Jan 13 Javascript
Angular.js 4.x中表单Template-Driven Forms详解
Apr 25 Javascript
jQuery读取本地的json文件(实例讲解)
Oct 31 jQuery
使用Angular CLI生成 Angular 5项目教程详解
Mar 18 Javascript
详解封装基础的angular4的request请求方法
Jun 05 Javascript
JS实现求5的阶乘示例
Jan 21 Javascript
JavaScript偏函数与柯里化实例详解
Mar 27 Javascript
vue路由插件之vue-route
Jun 13 Javascript
javascript实现倒计时提示框
Mar 02 Javascript
vue3.0生命周期的示例代码
Sep 24 #Javascript
js 将多个对象合并成一个对象 assign方法的实现
Sep 24 #Javascript
Vue3不支持Filters过滤器的问题
Sep 24 #Javascript
jdk1.8+vue elementui实现多级菜单功能
Sep 24 #Javascript
vue实现日历表格(element-ui)
Sep 24 #Javascript
从零开始用webpack构建一个vue3.0项目工程的实现
Sep 24 #Javascript
.netcore+vue 实现压缩文件下载功能
Sep 24 #Javascript
You might like
解析PHP的session过期设置
2013/06/29 PHP
php计算数组不为空元素个数的方法
2014/01/27 PHP
PHP以mysqli方式连接类完整代码实例
2014/07/15 PHP
PHP中使用asort进行中文排序失效的问题处理
2014/08/18 PHP
3种php生成唯一id的方法
2015/11/23 PHP
YII CLinkPager分页类扩展增加显示共多少页
2016/01/29 PHP
JavaScript创建命名空间(namespace)的最简实现
2007/12/11 Javascript
JS字符串截取函数实例
2013/12/27 Javascript
JS父页面与子页面相互传值方法
2014/03/05 Javascript
浅析Node在构建超媒体API中的作用
2014/07/30 Javascript
javascript实现的多个层切换效果通用函数实例
2015/07/06 Javascript
JavaScrip调试技巧之断点调试
2015/10/22 Javascript
基于BootStrap Metronic开发框架经验小结【九】实现Web页面内容的打印预览和保存操作
2016/05/12 Javascript
jQuery实现图像旋转动画效果
2016/05/29 Javascript
node.js实现回调的方法示例
2017/03/01 Javascript
angular-ngSanitize模块-$sanitize服务详解
2017/06/13 Javascript
React Native悬浮按钮组件的示例代码
2018/04/05 Javascript
详解使用angular框架离线你的应用(pwa指南)
2019/01/31 Javascript
nest.js 使用express需要提供多个静态目录的操作方法
2019/10/24 Javascript
[09:23]国际邀请赛采访专栏:iG战队VK,Tongfu战队Cu
2013/08/05 DOTA
如何利用Python分析出微信朋友男女统计图
2019/01/25 Python
Python中的集合介绍
2019/01/28 Python
解决Jupyter因卸载重装导致的问题修复
2020/04/10 Python
南威尔士家居商店:Leekes
2016/10/25 全球购物
萨克斯第五大道精品百货店: Saks Fifth Avenue
2017/04/28 全球购物
Shopty西班牙:缝纫机在线销售
2018/01/26 全球购物
教师自荐信范文
2013/12/09 职场文书
后备干部考察材料
2014/02/12 职场文书
学习标兵获奖感言
2014/02/20 职场文书
环保专项行动方案
2014/05/12 职场文书
学校教师师德师风承诺书
2015/04/28 职场文书
毕业设计论文致谢词
2015/05/14 职场文书
中国梦宣传标语口号
2015/12/26 职场文书
写一个Python脚本自动爬取Bilibili小视频
2021/04/24 Python
nginx作grpc的反向代理踩坑总结
2021/07/07 Servers
Golang 并发编程 SingleFlight模式
2022/04/26 Golang