跳到主要内容
版本:v8

你的第一个 Ionic 应用:Angular 版

Ionic 的强大之处在于,只需一套代码库,你就能使用 HTML、CSS 和 JavaScript 为任何平台构建应用。跟随我们的步骤,通过逐步创建一个真实应用来学习 Ionic 应用开发的基础知识。

以下是最终应用在三大平台上的运行效果:

备注

寻找涵盖 Ionic 4 和 Cordova 的旧版指南?请查看这里

我们将构建什么

我们将创建一个照片墙应用,能够使用设备相机拍照、在网格中显示照片,并将照片永久存储在设备上。

亮点包括:

  • 基于 Angular 的单一代码库,使用 Ionic Framework UI 组件在网页、iOS 和 Android 上运行。
  • 使用 Ionic 官方原生应用运行时 Capacitor 部署为原生 iOS 和 Android 移动应用。
  • 照片墙功能由 Capacitor 相机文件系统偏好设置 API 提供支持。

在本指南中引用的完整应用代码可在 GitHub 上找到。

下载必备工具

立即下载并安装这些工具,以确保获得最佳的 Ionic 开发体验:

  • Node.js 用于与 Ionic 生态系统交互。在此下载 LTS 版本
  • 代码编辑器 用于……编写代码!我们推荐 Visual Studio Code
  • 命令行界面/终端 (CLI)
    • Windows 用户:为获得最佳 Ionic 体验,我们推荐使用内置命令行 (cmd) 或 Powershell CLI,并以管理员模式运行。
    • Mac/Linux 用户:几乎任何终端都可以使用。

安装 Ionic 工具

在命令行终端中运行以下命令,安装 Ionic CLI (ionic)、用于在设备和模拟器/仿真器上运行原生二进制文件的 native-run,以及用于生成原生应用图标和启动画面的 cordova-res

备注

要在 Visual Studio Code 中打开终端,请转到终端 -> 新建终端。

npm install -g @ionic/cli native-run cordova-res
备注

-g 选项表示_全局安装_。当包全局安装时,可能会出现 EACCES 权限错误。

考虑设置 npm 在不提升权限的情况下全局运行。更多信息请参见解决权限错误

创建应用

接下来,创建一个使用“标签页”起始模板并添加 Capacitor 以实现原生功能的 Ionic Angular 应用:

ionic start photo-gallery tabs --type=angular
备注

当提示在 NgModulesStandalone 之间选择时,请选择 NgModules,因为本教程遵循 NgModules 方法。

这个起始项目包含三个预构建页面和 Ionic 开发的最佳实践。有了现成的通用构建模块,我们可以轻松添加更多功能!

接下来,切换到应用文件夹:

cd photo-gallery

接下来,我们需要安装必要的 Capacitor 插件以使应用的原生功能正常工作:

npm install @capacitor/camera @capacitor/preferences @capacitor/filesystem

PWA 元素

一些 Capacitor 插件,包括相机 API,通过 Ionic PWA 元素库提供基于 Web 的功能和 UI。

它是一个单独的依赖项,因此接下来安装它:

npm install @ionic/pwa-elements

接下来,通过编辑 src/main.ts 导入 @ionic/pwa-elements

import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
// 更改:添加以下导入
import { defineCustomElements } from '@ionic/pwa-elements/loader';

// 更改:在 `bootstrapModule` 调用之前调用元素加载器
defineCustomElements(window);

platformBrowserDynamic()
.bootstrapModule(AppModule)
.catch((err) => console.log(err));

就这样!现在进入有趣的部分——让我们看看应用的实际运行效果。

运行应用

接下来运行此命令:

ionic serve

看!你的 Ionic 应用现在正在 Web 浏览器中运行。你的大部分应用都可以直接在浏览器中构建和测试,从而大大提高了开发和测试速度。

照片墙

有三个标签页。点击“Tab2”标签页。这是一块空白画布,也是将其转变为照片墙的完美场所。Ionic CLI 具有实时重新加载功能,因此当你进行更改并保存时,应用会立即更新!

动画 GIF,展示 Ionic 应用中的实时重新加载功能,代码更改会立即更新 Web 浏览器中的应用

打开 /src/app/tab2/tab2.page.html。我们看到:

<ion-header [translucent]="true">
<ion-toolbar>
<ion-title> Tab 2 </ion-title>
</ion-toolbar>
</ion-header>

<ion-content [fullscreen]="true">
<ion-header collapse="condense">
<ion-toolbar>
<ion-title size="large">Tab 2</ion-title>
</ion-toolbar>
</ion-header>

<app-explore-container name="Tab 2 page"></app-explore-container>
</ion-content>

ion-header 代表顶部导航和工具栏,标题为“Tab 2”(由于支持 iOS 可折叠大标题,所以有两个)。将两个 ion-title 元素重命名为:

<ion-header [translucent]="true">
<ion-toolbar>
<!-- 更改:更新标题 -->
<ion-title> 照片墙 </ion-title>
</ion-toolbar>
</ion-header>

<ion-content [fullscreen]="true">
<ion-header collapse="condense">
<ion-toolbar>
<!-- 更改:更新标题 -->
<ion-title size="large">照片墙</ion-title>
</ion-toolbar>
</ion-header>

<app-explore-container name="Tab 2 page"></app-explore-container>
</ion-content>

我们将应用的视觉元素放在 <ion-content> 中。在这里,我们将添加一个打开设备相机并显示相机捕获图像的按钮。首先在页面底部添加一个浮动操作按钮 (FAB),并将相机图像设置为图标。

<ion-header [translucent]="true">
<ion-toolbar>
<ion-title>照片墙</ion-title>
</ion-toolbar>
</ion-header>

<ion-content>
<ion-header collapse="condense">
<ion-toolbar>
<ion-title size="large">照片墙</ion-title>
</ion-toolbar>
</ion-header>

<!-- 更改:添加浮动操作按钮 -->
<ion-fab vertical="bottom" horizontal="center" slot="fixed">
<ion-fab-button>
<ion-icon name="camera"></ion-icon>
</ion-fab-button>
</ion-fab>

<!-- 更改:移除或注释掉 `app-explore-container` -->
<!-- <app-explore-container name="Tab 2 page"></app-explore-container> -->
</ion-content>

接下来,打开 src/app/tabs/tabs.page.html。将中间标签页按钮的标签更改为“照片”,并将 ellipse 图标更改为 images

<ion-tabs>
<ion-tab-bar slot="bottom">
<ion-tab-button tab="tab1" href="/tabs/tab1">
<ion-icon aria-hidden="true" name="triangle"></ion-icon>
<ion-label>Tab 1</ion-label>
</ion-tab-button>

<ion-tab-button tab="tab2" href="/tabs/tab2">
<!-- 更改:更新图标 -->
<ion-icon aria-hidden="true" name="images"></ion-icon>
<!-- 更改:更新标签 -->
<ion-label>照片</ion-label>
</ion-tab-button>

<ion-tab-button tab="tab3" href="/tabs/tab3">
<ion-icon aria-hidden="true" name="square"></ion-icon>
<ion-label>Tab 3</ion-label>
</ion-tab-button>
</ion-tab-bar>
</ion-tabs>

这只是我们使用 Ionic 可以做的所有酷炫功能的开始。接下来,在 Web 上实现拍照功能,然后为 iOS 和 Android 构建。