ionic3项目开发脚手架(基于个人练习项目)

一.    基于ionic3的生产环境搭建

  1. 1.    配置安卓SDK:

安装jdk  ---》  安装AndroidSDK

(1)      安装jdk(无须配置环境变量)(版本推荐1.8.0_162)

下载链接:https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html

检查是否安装成功

(2)      安装Android SDK(版本-v 25.2.5 ,对应Android 7.1)

Android SDK Manager下载地址:http://www.androiddevtools.cn/

下载后进入安装工具页面,勾选如下

 

Tip:当前Android版本并非是市场占有率最高的版本 若有版本对应和兼容问题请参考https://blog.csdn.net/u010825468/article/details/78909550

 

  1. 2.    node.js环境搭建

(1)安装node.js ---》安装cordovaà安装ionicà运行第一个项目  ---》打包apk

(2)node.js版本为v8.11.1;下载地址:https://nodejs.org/en/download/

安装完成后会自动安装好npm包管理工具,在命令行输入以下指令则表示安装成功:

  

(3)安装cordova(版本6.5.0)

        

  

(4)安装ionic(版本3.20.0)

        

  

         tip:推荐使用淘宝镜像cnmp安装加快速度,具体参考博客:

                 https://www.cnblogs.com/chenglu/p/8608121.html

3. 使用工具

       (1)Visual Studio Code 2017或以上版本(DW,Webstorm,HBuild皆可)

             

       (2)Git中的Gitbash工具,主要用于方便命令行操作cordova和ionic指令

(运行ionic项目需通过命令行窗口cd到项目目录中,如果使用gitbash工具可直接在项目目录中右键点击gitbash打开命令行窗口cd到当前目录,提升工作效率)

-

二.    ionic3的第三方插件引入

  1. 1.     高德地图(JavaScript API V1.4.X

申请密钥key à在src目录下的index.html中引入 à在所需页面使用

具体方法见高德地图API:https://lbs.amap.com/api/javascript-api/example/map-lifecycle/map-show.

  1. 2.   百度地图(JavaScript API v3.0

申请密钥key à在src目录下的index.html中引入 à在所需页面使用

具体方法见百度地图API:http://lbsyun.baidu.com/index.php?title=jspopular/guide/show.

 

三.    服务器数据调用

1.有后台数据的情况下使用数据请求方法即可,具体见下文数据请求方法

2 . 无后台数据的情况下使用Mockjs模拟数据(生成随机数据,拦截 Ajax 请求;前后端分离技术)

使用方法:在src目录下的index.html中引入

<script src=’http://mockjs.com/dist/mock.js’></script>

然后在所需页面ts文件中的@component上方声明:declare let Mock:any;

详情见文档:http://mockjs.com/

四.    ionic3项目开发过程关键技术

  1. 1.   组件加载方式

推荐使用ionic3新特性,采用懒加载的方式避免代码冗余,加载速度过慢等问题;

其次是使用传统import注入的方法,这样可能导致的问题是页面引入来引入去造成混乱

使用方法参考:https://blog.csdn.net/qq_32107121/article/details/78453242

  1. 2.   页面跳转方式

一是通过NavController实现路由跳转,路由传值

二是通过navPush属性实现路由跳转传值(此种方式代码较为简洁)

两种方式在ionic3.x中均已在constructor构造函数中引入,无需自己手动引入

  1. 3.   数据请求方法和封装

(1)         HttpModule方法(异步)

(2)         HttpClientModule方法(异步)(相对于上面的方法更加简单)

(3)         三种处理异步代码的方式

①    Subscribe(),

②    Promise(),

③    Observable(),

参考:https://www.jianshu.com/p/3ad54d7d1077

(4)           通用封装请参考:https://blog.csdn.net/ligaoming_123/article/details/80908782.

https://www.jianshu.com/p/a9f8f6efdaa6.

(5)             本项目中封装的数据请求方法如下(因为该项目中请求数据都是针对项目特点统一用的get()方法,所以该封装仅供参考)

 

  1. 4.   全局变量的定义和使用

(1)   在src目录下的app目录下创建app.config.ts文件,并且在其中定义全局变量:

(2)   在所需页面ts文件中引入

(3)   使用demo:

五.ionic3项目开发性能优化

1.页面的生命周期事件合理运用

(1)ionViewDidLoad():页面加载完成触发,这里的“加载完成”指的是页面所需的资源已经加载完成,但还没进入这个页面的状态(用户看到的还是上一个页面)全程只会调用一次,即第一次进入页面时被调用,此后你无论怎样进进出出它都不会被触发。

(2)ionViewWillEnter():字面意义理解就是“我要进来了”的那一刻,这个时候页面刚刚开始切换。你可以在这时对页面的数据进行预处理,这个钩子是每次都会调用的。

(3)ionViewDidEnter():当这个钩子被触发的时候,用户已经进入到新页面了  (页面处于激活状态),同样也是每次都会调用。

(5)ionViewWillLeave():

      页面准备 (is about to) 离开时触发,这时用户刚刚触发了返回按钮或者相关的 事件。

(6)ionViewDidLeave():页面已经 (has finished) 离开时触发,页面处于非激活 状态了。

(7)ionViewWillUnload():页面中的资源即将被销毁时触发

(8)ionViewCanEnter ():每次调用返回boolean值,如果 ionViewCanEnter 返 回了false,页面进入就会被阻拦

(9)ionViewCanLeave ():每次调用返回boolean值,如果 ionViewCanLeave 返回了false,页面离开就会被阻拦

具体见博客:https://www.jianshu.com/p/72b704b5c9ed

2.ionic3新特性:懒加载

使用方法参考:https://blog.csdn.net/qq_32107121/article/details/78453242

  1. 3.   引用插件ionic-native-transitions提升页面切换效果,减少页面卡顿

详情见:https://www.cnblogs.com/luleixia/p/6782022.html

  1. 4.   自定义组件重复调用与封装服务

自定义组件:http://www.cnblogs.com/ruoqiang/p/9073190.html

封装服务:https://www.jianshu.com/p/447b09c3695e

ionic3.x脚手架(基于个人项目自用)的更多相关文章

  1. node-express脚手架生成的项目中实现浏览器缓存

    前言: 最近在做基于 node-express 的个人站点 朵朵视野 ,在站点发布之后自己在访问测试的过程中发现站点是没有缓存机制的,这样就导致每次访问站点都需要重新去加载资源,很消耗资源以及用户体验 ...

  2. 利用VUE-CLI脚手架搭建VUE项目

    前言 在学习完vue基础语法之后,学着利用vue-cli脚手架搭建一个项目,本篇随笔主要记录搭建的过程,供大家一起学习. 具体内容 搭建vue项目的准备工作 1.安装Nodejs.NPM以及VSCod ...

  3. 转:基于开源项目OpenCV的人脸识别Demo版整理(不仅可以识别人脸,还可以识别眼睛鼻子嘴等)【模式识别中的翘楚】

    文章来自于:http://blog.renren.com/share/246648717/8171467499 基于开源项目OpenCV的人脸识别Demo版整理(不仅可以识别人脸,还可以识别眼睛鼻子嘴 ...

  4. 用vue脚手架创建bootstrap-vue项目

    用vue脚手架创建bootstrap-vue项目 框架的地址:https://bootstrap-vue.js.org/docs/ 第一步 vue init webpack demo第二步 cd de ...

  5. 基于vue项目的组件中导入mui框架初始化滑动等效果时需移除严格模式的问题

    基于vue项目的组件中导入mui框架初始化滑动等效果时,控制台报错:Uncaught TypeError: 'caller', 'callee', and 'arguments' properties ...

  6. 让vue-cli脚手架搭建的项目可以处理vue文件中postcss语法

    图中&属于postcss的语法,这样书写样式可以清楚的看出选择器之前的层级关系,非常好用. 在利用vue-cli脚手架搭建的项目中如果不配置是不支持这种写法的,这样写不会报错,但是样式不生效. ...

  7. Grunt-Kmc基于KISSY项目打包

    Grunt-Kmc基于KISSY项目打包 1. Grunt-Kmc 是基于nodejs开发的,所以未安装nodeJS,先需要安装nodejs.安装步骤如下:        1. 下载安装文件,下载地址 ...

  8. jar包打包成exe示例(基于maven项目)

    jar包打包成exe示例(基于maven项目) 说明 针对基于maven的Java项目,通常会打包成jar, 如果要把jar文件包装成exe文件,仅需要在pom.xml配置文件中增加一个插件即可 这里 ...

  9. vue-cli脚手架构建了项目,想去除Eslint验证,如何设置?

    vue-cli脚手架构建了项目,想去除Eslint验证,如何设置? 在webpack.base.conf.js里面删掉下面: preLoaders: [ { test: /\.vue$/, loade ...

随机推荐

  1. spring boot入门篇

    Spring Boot[快速入门]   Spring Boot 概述 Build Anything with Spring Boot:Spring Boot is the starting point ...

  2. MVC设计模式与Java Web经典三层架构

    MVC设计模式 MVC的概念 首先我们需要知道MVC模式并不是javaweb项目中独有的,MVC是一种软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View)和控 ...

  3. 给国内知名大厂提BUG有感:安全是一种意识

    前言 本周一(2019.07.22),给某知名手机“大厂”提了个安全BUG,默默修复了后,周五回复我“已忽略”,此处省略上千字的心理活动..... 做安全的朋友说这都小事,国内氛围本来就不太好,hac ...

  4. spring与mybatis整合(扫描Mapper接口)

    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean" ...

  5. WPF滑块控件(Slider)的自定义样式

    前言 每次开发滑块控件的样式都要花很久去读样式代码,感觉有点记不牢,所以特此备忘. 自定义滑块样式 首先创建项目,添加Slider控件. 然后获取Slider的Window样式,如下图操作. 然后弹出 ...

  6. 保存MTLAB图片是想去掉白边

    在做一些matlab小实验的时候,生成的图片需要临时保存的时候会有多余的白边,如何能解决这种问题? 输入 iptsetpref('ImshowBorder','tight'); 后,再show一次图即 ...

  7. flask 异步celery使用

    在开发过程中,耗时长,超时的任务经常发生,比如:获取后端某个大文件数据超时.需要后端计算任务超时,等等, 此时我们就会很自然的想到异步方式,根据需要完成的任务创建一个task_id, 由前端来监听该任 ...

  8. vue过滤器的使用

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. curl工具使用实例

    curl是一个命令行工具,其基于libcurl库,用于发送网络请求,获取并展示响应数据,下面来看curl的具体用法. 1.下载网页源码 curl命令直接接URL,用于下载指定URL的网页源码,并将其显 ...

  10. Java虚拟机——Java内存区域

    1.运行时区域 Java虚拟机在执行Java程序的时候会把它管理的内厝划分为若干个不同功能的数据区域,如图所示 首先是程序计数器,程序计数器可以理解为当前程序执行的字节码的行号指示器,计数器中的数据即 ...