ionic3学习安排

一、环境准备

        1.1、安装Node.js(Windows下安装)

            1.1.1、下载地址:https://nodejs.org/en/download/

            1.1.2、安装后命令行下执行:node --version出现版本号表示安装成功

        1.2、npm安装:执行:npm install npm -g 命令

        1.3、ionic 安装

            1.3.1、资源包下载地址:http://ionicframework.com/docs/overview/#download

            1.3.2、命令行下执行:npm install -g cordova ionic 命令进行安装

            1.3.3、更新:npm update -g cordova ionic

            1.3.4、创建应用实例:ionic start 应用名称 初始类型(如:ionic start myApp tabs)

            1.3.5、试运行看是否安装成功(需要进入到myApp目录):ionic serve

        1.4、安装android SDK:

            下载android SDK并安装,然后环境变量添加ANDROID_SDK_HOME,路径为SDK的安装目录,然后在

            path中添加%ANDROID_SDK_HOME%\tools和%ANDROID_SDK_HOME%\platform-tools

       1.5、测试是否安装成功

            1.5.1、ionic start myproject tabs:创建一个带tabs栏和bottom栏的名字叫做myproject的

                工程

            1.5.2、cd myproject:进入项目路径

            1.5.3、ionic serve:浏览器调试,在浏览器中预览

            1.5.4、ionic cordova platform add android:添加android平台

            1.5.5、ionic cordova build android:编译安卓项目

            1.5.6、ionic cordova run android:真机运行,运行在安卓手机上,需要数据线连接到电脑,

                    并且手机打开开发者模式,允许调试。

2、第三、四、五天

    2.1、ionic g page 要创建的页面名称:创建空白页面,需要在命令窗口中执行,创建的页面在pages目录

        下,一个页面相当于一个文件夹,叫做组件,一个页面包括html、scss、ts文件一个,

    2.2、创建的项目的文件目录结构

        2.2.1、.sourcemaps

        2.2.2、node_modules:所有项目依赖库的存放点,包括ionic框架本身

        2.2.3、platforms:平台

        2.2.4、plugins:插件存放的目录

        2.2.5、resources:用来防止你编译应用的时候用到的闪屏和图标

        2.2.6、src:源代码资源目录,编码基本都在这里完成

        2.2.7、www:编译文件夹

        2.2.8、.editorconfig

        2.2.9、.gitignore

        2.2.10、config.xml:一些配置信息

        2.2.11、ionic.config.json

        2.2.12、package-lock.json

        2.2.13、package.json:版本配置信息之类的,可以用来更新版本

        2.2.14、tsconfig.json

        2.2.15、tslint.json

2.3、src目录建构

        2.3.1、app

            2.3.1.1、app.component.ts

            2.3.1.2、app.html

            2.3.1.3、app.module.ts:应用的根组件,每创建一个页面都要在这里注册申明才可以使用

            2.3.1.4、app.scss:用于声明在应用中全局使用的样式

            2.3.1.5、main.ts

        2.3.2、assets:一些静态资源存放的地方

        2.3.3、pages:创建的页面组件都在此目录之下

        2.3.4、theme:全局样式定义

        2.3.5、index.html:引入资源的地方

        2.3.6、manifest.json

        2.3.7、service-worker.js

    2.4、ionic标签和用法

        2.4.1、<ion-header>:页面头部,页眉

        2.4.2、<ion-navbar>:页面导航条

        2.4.3、<ion-title>:标题

        2.4.4、<ion-content>:页面内容部分,除了页眉和页脚的内容都放在这个地方

        2.4.5、<ion-fab>

        2.4.6、<img>:引入一张图片

        2.4.7、<ion-list>:列表

        2.4.8、<ion-item>:项目

        2.4.9、<ion-label>:标签、标记

        2.4.10、<ion-input>:文本输入框

        2.4.11、<button ion-button>:按钮

        2.4.12、<ion-icon>:小图标,ionic包含许多小图标可以供我们使用

        2.4.13、<ion-slides pager>:里面可放多个滑动页

        2.4.14、<ion-slide>:其中的一个滑动页,包含在<ion-slides pager>中

2.5、css样式标签和用法

        2.5.1、floating:文字上浮,一般在文本框前的提示中用:

                <ion-label floating>密码</ion-label>

        2.5.2、clearInput="true":文本框输入内容后,后面有个叉叉,点击可以清除文字

        2.5.3、clearOnEdit="true":文本输入的内容焦点离开文本框后,再次获取焦点时会清空文本内容,

            一般用在密码框中

        2.5.4、small:尺寸偏小的,一般用在按钮中,指定按钮类型为小按钮

        2.5.5、large:尺寸偏大的,一般用于按钮

        2.5.6、clear:清除样式

        2.5.7、block:设为块元素

        2.5.8、full:充满整个横向页面

        2.5.9、bottom:在页面底部显示

        2.5.10、padding:使用ionic定义的内边距

        2.5.11、color="danger":使用ionic定义的颜色,除此之外还有light、secondary、dark等颜色

        2.5.12、outline:大纲样式

        2.5.13、round:圆角,用在按钮可以使按钮变成圆角矩形

    2.6、js标签和用法

        2.6.1、(click)="函数名":点击时间调用函数

        2.6.2、this.navCtrl.setRoot(页面); :设置root页面

        2.6.3、this.navCtrl.push(某页面); :堆栈,跳到某页面

        2.6.4、this.navCtrl.pop(某页面); :出栈,弹出某页面,前提是这个页面之前已经进栈

3、第6、7天:周末休息

4、第8、9、10、11、12天

    4.1、ionic标签和用法

        4.1.1、#你取的一个标识名:

                给某个元素一个标识,之后可以通过这个标识对这个元素做更改处理,如#userName,在js里

                就能够有办法获取到。

        4.1.2、<ion-card>:卡片

        4.1.3、<ion-card-header>:卡片头

        4.1.4、<ion-card-content>:卡片内容

        4.1.5、<ion-row>:Grid的一行

        4.1.6、<ion-col>:Grid的一列

        4.1.7、<ion-refresher>:下拉刷新

    4.2、css样式标签和用法

        4.2.1、{{变量名}}:把变量的内容直接显示出来

        4.2.2、width-xx:Grid的宽度设置,例如width-10

    4.3、js标签和用法

        4.3.1、(input)="函数名" :输入框里面文本内容改变会实时调用函数

        4.3.2、public alertCtrl: AlertController:

                定义一个变量用于代表一个类,alertCtrl只是一个自定义的名字

        4.3.3、this.alertCtrl.create({

                title: ' ',

                message: ' ',

                buttons: [' '],

              })

                :创建一个弹窗,把窗口弹出还需要调用.present()

        4.3.4、*ngFor="let xxx of xxx":在ionic标签中使用,用于循环创建元素,相当于加强for循环

        4.3.5、*ngIf="Boolean":在ionic标签中使用,if条件判断,true的时候会执行

        4.3.6、<div [ngSwitch]="paragraphNumber">

                <p *ngSwitchCase="1">Paragraph 1</p>

                <p *ngSwitchCase="2">Paragraph 2</p>

                <p *ngSwitchCase="3">Paragraph 3</p>

                <p *ngSwitchDefault>Paragraph</p>

              </div>

            :这个是switch case语句

    4.4、命令

        4.4.1、ionic plugin add plugin-name:安装插件

        4.4.2、ionic plugin add cordova-plugin-geolocation:安装Ionic Native插件

        4.4.3、ionic g provider Data:生成数据提供者

    4.5、SQLite数据库连接与操作

        4.5.1、ionic cordova plugin add cordova-sqlite-storage:添加SQLite插件

        4.5.2、npm install --save @ionic-native/sqlite:安装

        4.5.3、在app.module.ts中添加 import { SQLite } from '@ionic-native/sqlite';

        4.5.4、在app.module.ts的providers:[]中加入SQLite

        4.5.5、在需要用到SQLite的ts文件中加入:

                import { SQLite, SQLiteObject } from '@ionic-native/sqlite';

        4.5.6、在需要用到SQLite的ts文件的constructor中加入:

                constructor(private sqlite: SQLite,) {}

    4.6、SQLite数据库DRUD核心代码(所有代码需要添加到TypeScript类中)

        4.6.1、连接,初始化

            database: SQLiteObject;

            ngOnInit() {

                this.initDB();

            }

            initDB(){

                this.sqlite.create({name: 'data.db',location: 'default'})

                .then((db: SQLiteObject) => {

                    db.executeSql('create table if not exists saveQuestion(id INTEGER PRIMARY KEY AUTOINCREMENT, questionName text NOT NULL)', {})//建表

                        .then(() => console.log('Executed SQL'))

                        .catch(e => console.log(e));

                this.database = db;

            });

        4.6.2、插入数据

            //插入数据

            insert(params){

                //console.log(params);

                //获取当前时间

                var date: string = new Date().toLocaleDateString();

                var time: string = new Date().toTimeString().substring(0,5);

                var datetime: string = date + " " + time;

                console.log(datetime);

                this.database.executeSql("INSERT INTO saveQuestion (questionName,important) VALUES (?,?);",[params.questionName,params.important])

                    .then(() => alert('暂存成功'))

                    .catch(e => console.log(e));//插入数据

            }

        4.6.3、修改数据

            //修改数据

            update(params){

                //console.log(params);

                var date: string = new Date().toLocaleDateString();

                var time: string = new Date().toTimeString().substring(0,5);

                var datetime: string = date + " " + time;

                console.log(datetime);

                this.database.executeSql("UPDATE saveQuestion set questionName=?,important=? WHERE id=?;",[params.questionName,params.important])

                    .then(() => alert('修改成功'))

                    .catch(e => console.log(e));

            }

        4.6.4、删除

            //删除

            buttonDelete(){

                this.database.executeSql("DELETE FROM saveQuestion WHERE id=?;",[放id])

                    .then(() => alert('删除成功'))

                    .catch(e => console.log(e));//删除数据

            }

        4.6.5、查询数据

            //查询

            query() {

                this.database.executeSql("select * from saveQuestion",{}).then((data)=>{

                    if ((uName == data.rows.item(0).userName) && (userPwd == data.rows.item(0).userPassword)) {

                        this.navCtrl.setRoot(RootHomePage);

                    }

                },(error)=>{

                    console.log('查询错误');

                });

            }

        4.6.6、一些注意事项

            4.6.6.1、数据库操作的结果都会返回到data变量接收,我们只需要把拿到的数据做处理就好了

            4.6.6.2、对数据操作只要把alert()替换成{}就好了,并且操作在{}内部完成

            4.6.6.3、取数据操作后的结果的方法:data.rows.item(n).字段名,n代表第几条记录,可能数

                    据库操作有多条数据,如data.rows.item(5).userPassword

    4.7、弹出警告窗

        4.7.1、在需要用到的ts文件中:

                import { AlertController } from 'ionic-angular/components';

        4.7.2、构造器中加入public alertCtrl: AlertController

        4.7.3、使用

            let alert = this.alertCtrl.create({

                title: '恭喜',

                message: '注册成功!',

                buttons: ['确定'],

            })

            alert.present();

    4.8、其它

        4.8.1、在类中定义的全局变量可以直接在页面中通过{{变量名}}取到变量的值

        4.8.2、下拉刷新

            <!-- 下拉刷新-->

            <ion-refresher (ionRefresh)="rootHomeRefresh($event)">

                <ion-refresher-content pullingIcon="arrow-dropdown" pullingText="下拉刷新" refreshingSpinner="circles" refreshingText="更新中..."></ion-refresher-content>

            </ion-refresher>

        4.8.3、密码框通过点击小图标显示或隐藏密码,在文本框中添加这个:

                type="{{eyeshow?'text':'password'}}",

              在小图标中添加这个:

                (click)="eyeshow= !eyeshow"

              就能实现点击显示,再点击隐藏的功能

4.8.4、一些重要资料链接

4.8.4.1、http://www.jianshu.com/p/ca2f87cd3280

4.8.4.2、http://www.cnblogs.com/greyzeng/p/5557947.html

4.8.4.3、http://ionicframework.com/docs/storage/#set

4.8.4.4、http://blog.csdn.net/zuoyiran520081/article/details/56017320?locationNum=4&fps=1

4.8.4.5、http://blog.csdn.net/h254532699/article/details/54382123

4.8.4.6、https://www.cnblogs.com/huihuihui/p/6930412.html

4.8.4.7、http://blog.csdn.net/u012379815/article/details/51775956

4.8.4.8、http://blog.csdn.net/qq993284758/article/details/77679283

4.8.4.9、http://blog.csdn.net/u011537073/article/details/61004203

4.8.4.10、http://blog.csdn.net/li00828/article/details/78318255

4.8.4.11、http://ionicframework.com/docs/api/platform/Keyboard/

4.8.4.12、http://ionicframework.com/docs/native/keyboard/

作者:li_zean

来源:CSDN

原文:https://blog.csdn.net/li_zean/article/details/79260715

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容