当前位置:硬件测评 > 浅谈angular2+ionic2

浅谈angular2+ionic2

  • 发布:2023-09-25 05:43

-->

浅谈angular2+ionic2

 

前言:

不要用angular的语法去写angular2,有人说二者就像Java和JavaScript的区别。

 

1、 项目所用:angular2+ionic2+typescript

2、 项目结构

3、 Src目录是我们本地开发的目录文件,www我ionic2编译后生成的文件

4、 每个文件夹下面都有三个文件  分别是.Html、.scss、.ts分别代表结构文件、样式文件、功能文件。也就是HTML+css+js,ionic2+angular2所用的是typescript插件替代js。了解 typescript

5、 注意事项node_modules文件放在本地即可不必提交。

6、 开发准备:

1、 安装node

a)         Npm install  -g  node

2、 安装ionic

a)         Npm install –g ionic

3、 安装typescript

a)         Npm install –g typescript

7、 开始开发(一个demo并非项目开发)

案例实现的功能:获取后台数据进行页面渲染、新增页面、页面间跳转            

1、 创建模板

a)  ionic start  projectname tutorial --v2

projectname表示你的文件名

tutorial表示创建的模板样式,ionic总有三套模板

若不写则表示默认创建tabs模板

                   --v2表示创建ionic2   不写着默认创建ionic

2、运行

模板创建好后  ionic serve

你会看到

我们还可以跨平台运行 ionic serve –l

当你第一次产生ionic2应用程序,这是生成的项目结构

├── ├── config.xml

├── hooks

├── ionic.config.json

├── node_modules

├── package.json

├── platforms

├── plugins

├── resources

├── src

├── tsconfig.json

├── tslint.json

我们几乎总是会花90%的时间在src文件夹,这就是应用程序逻辑。然而整个应用程序通常从一个简单的src /index.html文件,它在构建复制到一个新文件夹www

3、

src/index.html

     

Ionic App

我们几乎从不碰这个文件。

注意< ion-app > < / ion-app >:这是ionic的应用程序的入口点。这叫做根组件的应用程序。

我们很快就会看到它的定义,但这就是angular2应用程序的构建。总有一种 < /root-component>结构指数。html页面。这个文件的其他部分只是装载离子构建依赖关系。

4、      简要描述项目结构。

5、      config.xml -这包含配置应用程序的名称,和包名,将被用于我们的应用程序安装到一个实际的设备。

src -这就是我们花费我们大部分的时间建立应用程序。它包含结构化程序的源代码。

node_modules -包含了npm包

package.json 这些都是包构建ionic应用程序所必需的

platforms -这就是平台的具体构建,构建工具和包/库存储。你会发现一个文件夹你正在构建的平台。例如,添加一个平台, ionic platform add android,这将文件夹安卓文件夹添加到文件夹中。

plugins -这就是cordova plugins。cordova插件允许你的应用在移动设备本地功能,e。g访问的媒体存储设备,甚至蓝牙API。

resources -这也包含特定于平台的资源(如图标和启动屏幕)

6、      最后,让我们仔细看看src / app / app.module.ts

import { NgModule } from '@angular/core';

import { IonicApp, IonicModule } from 'ionic-angular';

import { MyApp } from './app.component';

import { HelloIonicPage } from '../pages/hello-ionic/hello-ionic';

import { ItemDetailsPage } from '../pages/item-details/item-details';

import { ListPage } from '../pages/list/list';

7、

@NgModule({

declarations: [

MyApp,

HelloIonicPage,

ItemDetailsPage,

ListPage

],

imports: [

IonicModule.forRoot(MyApp)

],

bootstrap: [IonicApp],

entryComponents: [

MyApp,

HelloIonicPage,

ItemDetailsPage,

ListPage

],

providers: []

})

export class AppModule {}

7、由于我们使用这个angular2模块结构,我们需要申报前手的所有组件,提供者、指示或管道,我们的应用程序使用。我们会将这些添加到这个文件。您可以看到,这个模板导入所有它需要的页面,添加的宣言财产@NgModule entryComponents财产。这也是我们导入根组件中定义的地方src / app / app.component.ts

我们的ionic的应用将有3个主要页面。一个对于github用户,另一个用于github组织,另一个用于github库。最后两页只是视图来显示我们可以与侧边栏导航,他们将没有任何内容。然而,github用户页面将使您能够查看用户的详细信息。

8、在src /页面中删除所有文件夹。然后我们将首先快速创建三个主要页面的帮助下离子CLI。运行这些在你的终端

ionic g page users

ionic g page repos

ionic g page organisations

你会发现src/pages文件下生成了三个页面

User-details是后面开发所生成并非这次所生成的

9、打开三个文件夹中的html文件

< ion-navbar >负责导航栏。我们可以说这是在这种情况下的导航组件。

ion-button是ionic的建于指令2按钮。这个例子中有一个

icon-only指令来表明这是一个图标按钮。

menuToggle是一个建在指令帮助切换菜单。

然后我们有< ion-icon >,这是一个组件负责处理图标。我们只是给它的图标名称基于这个ionic图标列表。

< ion-title >显示页面标题。

< ion-content >保存页面的内容。它有一个填充指令提供一点填充内容。

10、打开新创建三个文件中的ts文件

      ionViewDidLoad()方法是一个ionic生命周期钩。一旦一个离子视图加载它他就进行加载此函数内的代码

我们会将这些页面添加到导航。去src / app / app.component.ts我们会做一些改变。如果你仔细检查有一个类属性叫做pages。这就是组成的sidenav(ion-menu)视图,显示在

src / app / app.html。

Pages

我们不会碰这个文件,我们将使用它生成的。按钮有一个* ngFor =“让p的页面”指令,这就是angular2执行重复的模板。这仅仅意味着遍历页面收集和生成一个集合中的每一项的模板。如果我们改变页面属性的值,我们改变的内容sidenav(ion-menu)。

< ion-nav >是显示页面导航。根属性绑定到页面中rootPage类。我们很快就会看到这个详细定义。

sidenav添加正确的页面,我们将做一些更改src / app / app.component.ts文件。我有删除两个导入语句(HelloIonicPage和ListPage)顶部的页面删除,并为我们创建的页面添加导入语句。

11、打开src/app/app.component.ts

      UsersPage ReposPage和OrganisationsPage组件类,代表页面搭建当我们生成一个单独的页面。你可以检查他们在src/pages/users/users.ts 、 src/pages/repos/repos.ts 和src/pages/organisations/organisations.ts.

然后我们将编辑页面类属性来匹配我们的新页面。

// imports commented out for brevity

export class MyApp {

@ViewChild(Nav) nav: Nav;

// make UsersPage the root (or first) page

rootPage: any = UsersPage;

pages: Array<{title: string, component: any}>;

constructor(public platform: Platform,  public menu: MenuController) {

this.initializeApp();

// set our app's pages

this.pages = [

{ title: 'Users', component: UsersPage },

{ title: 'Repos', component: ReposPage },

{ title: 'Organisations', component: OrganisationsPage },

];

}

initializeApp() {

this.platform.ready().then(() => {

// Okay, so the platform is ready and our plugins are available.

// Here you can do any higher level native things you might need.

StatusBar.styleDefault();

});

}

openPage(page) {

// close the menu when clicking a link from the menu

this.menu.close();

// navigate to the new page if it is not the current page

this.nav.setRoot(page.component);

}

}

注意,rootPage UsersPage类属性设置。记住,在视图中src/app/app.html。html < ion-nav >根属性绑定到这个rootPage。这意味着UsersPage应用程序加载时将显示第一个。

openPage方法负责当点击打开页面。如果你看回ssrc/app/app.html。我们可以看到

绑定到该方法的列表页面(点击)=“openPage(p)”。在一个页面,并打开它。很简单,是吧?

最后我们需要做什么来完成这个设置是我们页面告诉角。这是在src / app / app.module完成。ts文件。

导入所有的三个页面,并将它们添加到声明和entryComponents @NgModule的属性。删除我们不使用的进口

打开

src/app/app.module.ts

import { NgModule } from '@angular/core';

import { IonicApp, IonicModule } from 'ionic-angular';

import { MyApp } from './app.component';

import { UsersPage } from '../pages/users/users';

import { ReposPage } from '../pages/repos/repos';

import { OrganisationsPage } from '../pages/organisations/organisations';

@NgModule({

declarations: [

MyApp,

UsersPage,

ReposPage,

OrganisationsPage

],

imports: [

IonicModule.forRoot(MyApp)

],

bootstrap: [IonicApp],

entryComponents: [

MyApp,

UsersPage,

ReposPage,

OrganisationsPage

],

providers: []

})

export class AppModule {}

运行程序

11、获得Github用户

这里有一个服务是从从https://www.sychzs.cn/users获得Github用户。页面列出了大约30的github json格式的用户。

首先,我们需要创建一个Github的用户模型。这是一个类,它拥有我们想要的相关字段github的用户,从github提供很多细节。

在src文件夹中创建一个文件夹叫models。这就是我们将把我们的用户模型和其他模型以后我们可能希望创建。在src / user.ts模型并添加一个文件 user.ts.

src/models/user.ts

// User model based on the structure of github api at

// https://www.sychzs.cn/users/{username}

export interface User {

login: string;

avatar_url: string;

public_repos: number;

public_gists: number;

followers: number;

following: number;

}。

我们只包含属性我们需要从github的回应。现在我们定义了我们的模型,我们可以创建一个github-users提供者来让我们把用户从github。生成一个提供者在终端运行以下

ionic g provider github-users

这将创建一个文件夹叫providers src目录中,github-users.ts文件。

我们稍微修改生成的src / providers / github-users.ts文件

import { Injectable } from '@angular/core';

import { Http } from '@angular/http';

import { Observable } from 'rxjs/Rx';

import 'rxjs/add/operator/map';

import { User } from '../models/user';

@Injectable()

export class GithubUsers {

githubApiUrl = 'https://www.sychzs.cn';

constructor(public http: Http) { }

// Load all github users

load(): Observable {

return this.http.get(`${this.githubApiUrl}/users`)

.map(res => res.json());

}

}

@Injectable()decorator是angular2声明它的服务/提供者

Observable 的引入是必要的,因为我们将返回github API调用的结果作为一个Observable 。认为一个Observable 的数据流可以订阅。我们来看看这一点细节。

我们做的第一件事是要导入的用户模型导入{User} from '../models/user'.

负载然后我们添加一个函数,该函数将返回一个Observable

我们做一个请求到github api,并解析json响应与res.json(),然后我们扮演一个数组的用户与用户[]> < res.json()。这是作为一个Observable 返回,我们会看到用户订阅。

使用我们的服务在整个应用程序,我们需要将它添加到src / app / app.module.ts文件。

// Imports commnted out for brevity

import { GithubUsers } from '../providers/github-users';

@NgModule({

declarations: [

// Declarations commented out for brevity

],

imports: [

IonicModule.forRoot(MyApp)

],

bootstrap: [IonicApp],

entryComponents: [

// Entry Components commented out for brevity

],

providers: [GithubUsers] // Add GithubUsers provider

})

export class AppModule {}

我们只是导入GithubUsers并添加NgModule的提供者属性。

12、查看Github用户

现在我们有我们的用户,查看用户页面。我们可以做这个之前,我们需要测试我们是否让用户从我们的provider。

src/pages/users/users.ts 文件,使它看起来跟下面的一样。

import { Component } from '@angular/core';

import { NavController } from 'ionic-angular';

import { User } from '../../models/user';

import {  GithubUsers } from '../../providers/github-users';

@Component({

selector: 'page-users',

templateUrl: 'users.html'

})

export class UsersPage {

users: User[]

constructor(public navCtrl: NavController, private githubUsers: GithubUsers) {

githubUsers.load().subscribe(users => {

console.log(users)

})

}

}

src/pages/users/users.ts

      // Imports commented out for brevity

@Component({

// Commented out for brevity

})

export class UsersPage {

users: User[]

constructor(public navCtrl: NavController, private githubUsers: GithubUsers) {

githubUsers.load().subscribe(users => {

this.users = users;

})

}

}

src/pages/users/users.html

相关文章