1、修改tabs页的图标,关键是 outline

在使用自定义图标的时候,需要修改 /theme/icons.scss 文件,但是如何定义选中前后的分别使用哪个图标呢
  定义选中前的状态
  .ion-ios-data-outline::before { content: url("../assets/fonts/dataIcon.svg");}
  定义选中后的状态
  .ion-ios-file:before { content: url("../assets/fonts/fileIcon2.svg");}

2、ts 中获取html 参数的值,segment 是e.value, select是e,不能用e.value

<ion-segment [(ngModel)]="choice" (ionChange)="segmentChanged($event)">

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

<ion-select interface="popover" (ionChange)="homeRunChanged($event)">

homeRunChanged(e) {
  console.log(e);
  this.commonService.home_run(e);
}

3、ts文件中获取map型参数的陷阱

在ts文件中,定义类型 result: any[],后来赋值 {name:bob}
  在ts中使用 result.name,编译报错
  该使用 result['name'] 注意有两个单引号

但在html文件中
  可以使用result.name, result['name'] 两种方式获取到值,前一种是angular 的方式,后一种是js 的方式

4、先loading,然后alert,使用onDidDismiss方法

let loader = this.loadingCtrl.create({
  content: "正在提交",
  duration: 3000
});
loader.present();

loader.onDidDismiss(() => {
    let toast = this.toastCtrl.create({
    message: '非常感谢您帮我们变得更好',
    duration: 2000,
    position: 'middle'
  });
  toast.present(toast);
});

也可以手动结束加载 loader.dismiss(); 或 loader.dismissAll(); 然后再alert

5、传来的json数据,如何用到echarts的饼图中

比如json数据,{"message":"ok","result":{"cz":[122.25,160.07,367.37],"industry":["石油加工","化学原料","汽车"]},"status":"200"}
但是在饼图中的数据,必须是 {'name' : '石油加工' ,'value' : 122.25}这种形式

需要添加一个转换方法
chart_data1: any=[];
this.httpApi.get<ResponseType>('/services/ea_AppIndustryStructureService/industryAccProValue?month=201704')
  .subscribe(
    data => {
      let chart_data1_x = data['result']['industry'];
      let chart_data1_y = data['result']['cz'];
      for (let i = 0; i < chart_data1_x.length; i++) {
        this.chart_data1.push({'name': chart_data1_x[i] , 'value': chart_data1_y[i]});
      }
      console.log(this.chart_data1);
      this.clickChart1();
    });

6、ngswitch 陷阱

segment 搭配上 ngswitch,可以实现非常好看的页面,但是后来发现也有一些不好的地方
  比如下面这个页面中,选项卡 A和B,A中包含了aaa,B中包含了bbb。他们在同一个html页面中,但是在选项卡切换为A时,获取不到bbb元素;选项卡切换为B,获取不到aaa元素。


  当时为了实现我的效果,就没有使用ngswitch,而是定义了两个div,一个显示一个隐藏

原创文章,欢迎转载,转载请注明出处!

Ionic开发遇到的坑整理的更多相关文章

  1. ionic开发遇到的坑及总结

    前言 ionic是一个用来开发混合手机应用的,开源的,免费的代码库.可以优化html.css和js的性能,构建高效的应用程序,而且还可以用于构建Sass和AngularJS的优化.ionic会是一个可 ...

  2. 关于ionic开发中遇到的坑与总结

    这次是第二次使用ionic开发混合app,今天算是对这个框架做一个总结,基础的我就不再重复了,网上都有教程.我就说说自己的心得和遇见的各种坑, 之后会陆续补充,想到什么说什么吧. 1.关于ionic效 ...

  3. 分享 Ionic 开发 Hybrid App 中遇到的问题以及后期发布 iOS/Android 的方方面面

    此篇文章主要整理了最近在使用 Ionic 开发 Hybrid App 过程中遇到的一些疑难点以及后期发布生成 iOS 和 Android 版本过程中的种种问题. 文章目录 Ionic 简介和项目需求介 ...

  4. Ionic开发Hybrid App问题总结

    http://ionichina.com/topic/5641b891b903cba630e25f10 http://www.cnblogs.com/parry/p/issues_about_buil ...

  5. Ionic开发实战

    转自:http://blog.csdn.net/i348018533/article/details/47258449/ 折磨的两个月!Ionic从零单排,到项目发布!遇到了很多问题但都一一解决了,此 ...

  6. Android使用WebView开发常见的坑

    原文链接:http://mp.weixin.qq.com/s?__biz=MzAwODE1NTI2MQ==&tempkey=uP3a%2BOgIN7vPbLfJp3BTCl2KabYi1%2F ...

  7. 文顶顶iOS开发博客链接整理及部分项目源代码下载

    文顶顶iOS开发博客链接整理及部分项目源代码下载   网上的iOS开发的教程很多,但是像cnblogs博主文顶顶的博客这样内容图文并茂,代码齐全,示例经典,原理也有阐述,覆盖面宽广,自成系统的系列教程 ...

  8. 简述移动端IM开发的那些坑:架构设计、通信协议和客户端

    1.前言 有过移动端开发经历的开发者都深有体会:移动端IM的开发,与传统PC端IM有很大的不同,尤其无线网络的不可靠性.移动端硬件设备资源的有限性等问题,导致一个完整的移动端IM架构设计和实现都充满着 ...

  9. Ionic 开发环境搭建

    android sdk环境搭建并非易事,本人经过无数失败,才使用以下方式成功 配置Ionic 开发环境 1.下载JDK并配置Java运行环境 http://www.oracle.com/technet ...

随机推荐

  1. portscaner 多线程、多协程并发端口扫描

    import socket,time,re,sys,os,threading import gevent from gevent import monkey monkey.patch_all() so ...

  2. 简约时尚商城wordpress主题-storefront

    wordpress主题:简约时尚商城主题-storefront 简简单的商城模板,挺适合一些懒人所用.后天功能也挺不错,希望大家喜欢. WooCommerce 集成 商城是基为用 WooCommerc ...

  3. 如何恢复Eclipse中被误删除的文件

    在使用Eclipse时,可能会不小心误删除一些文件,没关系,Eclipse有个非常强大的功能,能让这些误删除的文件恢复回来,下面就来介绍一下. 工具/原料   Eclipse Kepler 方法/步骤 ...

  4. java核心API学习

    1:java.lang  (Object.String.StringBuffer.Thread.System.ClassLoader.Class.Runtime.包装类等)

  5. linux 服务器名 访问 shh免密码登录

    以根用户登录,或者登录后切换到根用户,然后在提示符下输入hostname命令,可以看出当前系统的主机名为localhost.localdomain.   更改/etc/sysconfig下的netwo ...

  6. 【学亮IT手记】利用字节流复制图片

  7. Junit概述

    Junit ->  java unit.也就是说Junit是xunit家族中的一员. unit   <- unit test case,即单元测试用例. Junit  = java uni ...

  8. flutter屏幕适配

    现在的手机品牌和型号越来越多,导致我们平时写布局的时候会在个不同的移动设备上显示的效果不同, 比如我们的设计稿一个View的大小是300px,如果直接写300px,可能在当前设备显示正常,但到了其他设 ...

  9. java 从键盘录入的三种方法

    详细内容连接 https://blog.csdn.net/StriverLi/article/details/52984066

  10. uname -r查询版本不是安装的版本的问题

    uname -r 查出来的版本与/lib/modules下面的内核版本不匹配.啥原因? 第一步,先strace uname -r看看这个uname -r到底从哪里获取的版本. strace没有看出来 ...