EmberJS 快速指南



EmberJS - 概述

什么是 Ember.js?

Ember.js 是一个开源的、免费的 JavaScript 客户端框架,用于开发 Web 应用程序。它通过提供包含数据管理和应用程序流程的完整解决方案,允许构建客户端 JavaScript 应用程序。

Ember.js 的原始名称是 SproutCore MVC 框架。它由 Yehuda Katz 开发,并于 2011 年 12 月 首次发布。Ember.js 的稳定版本是 2.10.0,于 2016 年 11 月 28 日发布。

为什么选择 Ember.js?

请考虑以下几点,以了解 Ember.js 的用途:

  • Ember.js 是一个在 MIT 许可下的开源 JavaScript 框架。

  • 它使用 HTMLBars 模板引擎(Handlebars 模板引擎的超集)提供新的绑定语法。

  • 它提供 Glimmer 渲染引擎以提高渲染速度。

  • 它提供 命令行界面 (CLI) 实用程序,可将 Ember 模式集成到开发流程中,并轻松关注开发人员的生产力。

  • 它支持 数据绑定,以创建两个属性之间的链接,当一个属性更改时,另一个属性将使用新值进行更新。

Ember.js 的特性

以下是 Ember.js 的一些最突出的特性:

  • Ember.js 用于创建可重用且易于维护的 JavaScript Web 应用程序。

  • Ember.js 以 HTMLCSS 为开发模型的核心。

  • 它提供实例初始化器。

  • 路由是 Ember.js 的核心特性,用于管理 URL。

  • Ember.js 提供 Ember 检查器工具用于调试 Ember 应用程序。

  • Ember.js 使用模板,如果应用程序的内容发生更改,则有助于自动更新模型。

EmberJS - 安装

在您的系统中配置 Ember.js 很容易。通过使用 Ember CLI(命令行界面)实用程序,您可以创建和管理您的 Ember 项目。Ember CLI 处理各种应用程序资产管理,例如连接、缩小和版本控制,并提供生成器来生成组件、路由等。

要安装 Ember CLI,您需要具备以下依赖项:

  • Git - 它是一个开源版本控制系统,用于跟踪对文件所做的更改。有关更多信息,请查看 git 的官方网站。Ember 使用 Git 来管理其依赖项。

  • Node.js 和 npm - Node.js 是一个开源的,用于开发服务器端和网络应用程序。它是用 JavaScript 编写的。NPM 是一个节点包管理器,用于安装、共享和管理项目中的依赖项。Ember CLI 使用 Node.js 运行时和 npm 来获取依赖项。

  • Bower - 它用于管理组件,例如 HTML、CSS、JavaScript、图像文件等,可以使用 npm 安装。

  • Watchman - 此可选依赖项可用于监视文件或目录,并在它们更改时执行某些操作。

  • PhantomJS - 此可选依赖项可用于运行基于浏览器的单元测试以与网页交互。

安装 Ember CLI

Ember CLI 将 Ember 模式集成到开发流程中,并轻松关注开发人员的生产力。它用于使用 Ember.js 和 Ember 数据创建 Ember 应用程序。

您可以使用 npm 安装 Ember,如下面的命令所示:

npm install -g ember-cli

要安装测试版,请使用以下命令:

npm install -g [email protected]

要检查 Ember 的安装是否成功,请使用以下命令:

ember -v

执行上述命令后,它将显示类似以下内容:

ember-cli: 2.10.1
node: 0.12.7
os: win32 ia32

EmberJS - 核心概念

Ember.js 具有以下核心概念:

  • 路由器
  • 模板
  • 模型
  • 组件
Emberjs Core Concepts

路由器和路由处理器

通过在地址栏中输入 URL 并用户点击应用程序中的链接来加载应用程序。Ember 使用路由器将 URL 映射到路由处理器。路由器将现有 URL 与路由匹配,然后将其用于加载数据、显示模板和设置应用程序状态。

路由处理器执行以下操作:

  • 它提供模板。

  • 它定义了模板可访问的模型。

  • 如果用户无权访问应用程序的特定部分,则路由器将重定向到新路由。

模板

模板是面向最终用户的强大 UI。Ember 模板使用 Handlebars 模板 的语法提供应用程序的用户界面外观。它构建前端应用程序,就像普通的 HTML 一样。它还支持正则表达式并动态更新表达式。

模型

路由处理器呈现将信息持久化到 Web 服务器的模型。它操作存储在数据库中的数据。模型是一个简单的类,它扩展了 Ember Data 的功能。Ember Data 是一个与 Ember.js 紧密耦合的库,用于操作存储在数据库中的数据。

组件

组件控制用户界面行为,包括两个部分:

  • 用 JavaScript 编写的模板

  • 用 JavaScript 编写的源文件,提供组件的行为。

EmberJS - 创建和运行应用程序

您可以轻松地在您的系统中配置 Ember.js。Ember.js 的安装在 EmberJS 安装 章节中进行了说明。

创建应用程序

让我们使用 Ember.js 创建一个简单的应用程序。首先创建一个文件夹来创建您的应用程序。例如,如果您创建了“emberjs-app”文件夹,则导航到此文件夹:

$ cd ~/emberjs-app

在“emberjs=app”文件夹内,使用 new 命令创建一个新项目:

$ ember new demo-app

创建项目时,new 命令将提供以下带有文件和目录的目录结构:

|-- app
|-- bower_components
|-- config
|-- dist
|-- node_modules
|-- public
|-- tests
|-- tmp
|-- vendor

bower.json
ember-cli-build.js
package.json
README.md
testem.js
  • app - 它指定模型、路由、组件、模板和样式的文件夹和文件。

  • bower_components / bower.json - 它用于管理组件,例如 HTML、CSS、JavaScript、图像文件等,可以使用 npm 安装。bower_components 目录包含所有 Bower 组件,bower.json 包含 Ember、Ember CLI Shims 和 QUnit 安装的依赖项列表。

  • config - 它包含 environment.js 目录,用于配置应用程序的设置。

  • dist - 它包含构建应用程序时部署的输出文件。

  • node_modules / package.json - NPM 是 Node.js 的节点包管理器,用于安装、共享和管理项目中的依赖项。package.json 文件包含应用程序的当前 npm 依赖项,列出的包将安装在 node_modules 目录中。

  • public - 它包含资产,如图像、字体等。

  • vendor - Bower 不控制前端依赖项(例如 JavaScript、CSS)所在的目录。

  • tests / testem.js - 自动化测试存储在 tests 文件夹下,Ember CLI 的测试运行器 testem 位于 testem.js 中。

  • tmp - 它包含 Ember CLI 的临时文件。

  • ember-cli-build.js - 它指定如何使用 Ember CLI 构建应用程序。

运行应用程序

要运行应用程序,请导航到新创建的项目目录:

$ cd demo-app

我们创建了新项目,可以使用以下命令运行它:

$ ember server

现在打开浏览器并导航到 https://127.0.0.1:4200/。您将看到如下图所示的 Ember 欢迎页面:

Ember.js App Example

EmberJS - 对象模型

在 Ember.js 中,所有对象都派生自 Ember.Object。面向对象分析和设计技术称为对象建模。Ember.Object 使用类系统支持诸如 mixin 和构造函数方法之类的特性。Ember 使用 Ember.Enumerable 接口扩展 JavaScript Array 原型以提供数组的观察更改,并使用 格式化和本地化 方法扩展 String 原型

下表列出了 Ember.js 中不同类型的对象模型及其说明:

序号 类型和说明
1 类和实例

类是一个模板或蓝图,它具有变量和函数的集合,而实例与该类的对象相关。您可以使用 Ember.Object 的 extend() 方法创建新的 Ember 类。

2 重新打开类和实例

这只不过是在不重新定义的情况下更新类实现。

3 计算属性

计算属性将函数声明为属性,Ember.js 会在需要时自动调用计算属性,并将一个或多个属性组合在一个变量中。

4 计算属性和聚合数据

计算属性访问数组中的所有项以确定其值。

5 观察者

观察者观察属性,例如计算属性,并更新计算属性的文本。

6 绑定

绑定是 Ember.js 的一项强大功能,它有助于在两个属性之间建立链接,如果其中一个属性发生更改,则另一个属性会自动更新。

EmberJS - 路由器

路由器是 EmberJs 的核心功能,它将 URL 转换为一系列模板,并表示应用程序的状态。Ember 使用路由器将 URL 映射到路由处理程序。路由器将当前 URL 与用于加载数据、显示模板和设置应用程序状态的其他路由匹配。

路由处理程序执行一些操作,例如:

  • 它提供模板。

  • 它定义模型,该模型可供模板访问。

  • 如果用户无权访问应用程序的特定部分,则路由器将重定向到新路由。

下表列出了 Ember.js 中的不同路由器及其说明:

序号 类型和说明
1 定义路由

路由器将当前 URL 与负责显示模板、加载数据和设置应用程序状态的路由匹配。

2 指定路由的模型

要指定路由模型,您需要一个模板来显示模型中的数据。

3 渲染模板

路由用于将外部模板渲染到屏幕上。

4 重定向

这是一种 URL 重定向机制,当找不到请求的 URL 时,它会将用户重定向到不同的页面。

5 阻止和重试转换

在路由转换期间,可以使用transition.abort()transition.retry() 方法分别中止和重试转换。

6 加载/错误子状态

Ember 路由器提供有关路由加载的信息以及加载路由时发生的错误。

7 查询参数

查询参数出现在 URL 中“?”标记的右侧,表示为可选的键值对。

8 异步路由

Ember.js 路由器能够通过使用异步路由来处理应用程序中的复杂异步逻辑。

EmberJS - 模板

模板用于在多个页面上创建标准布局。更改模板时,基于该模板的页面会自动更改。模板提供标准化控件

下表显示了有关模板的更多详细信息:

序号 类型和说明
1 Handlebars 基础知识

Handlebars 模板库允许通过包含静态 HTML 和动态内容来构建丰富的用户界面。

2 内置助手

助手为模板提供额外功能,并将模型和组件中的原始值修改为适合用户的格式。

3 条件语句

Ember.js 定义了两个条件语句,有助于控制程序流程。

4 显示项目列表

您可以使用#each 助手显示数组中的项目列表。

5 显示对象中的键

您可以使用#each-in 助手显示对象中的键。

6 链接

可以使用{{link-to}} 组件创建指向路由的链接。

7 操作

可以使用{{action}} 助手使 HTML 元素可点击。

8 输入助手

可以使用 Ember.js 中的{{input}}{{textarea}} 助手创建常见的表单控件。

9 开发助手

可以使用 Handlebars 和 Ember 的一些助手简化模板开发。

10 编写助手

您可以为模板添加额外功能,并将模型和组件中的原始值转换为适合用户的格式。

EmberJS - 组件

Ember.js 组件使用 W3C Web 组件规范并提供真正的封装 UI 小部件。它包含三个主要规范:模板Shadow DOM自定义元素。组件在 data-template-name 中声明,它具有路径名而不是普通字符串,并且以“components/”为前缀。

下表列出了操作的动作事件:

序号 动作事件和说明
1 定义组件

您可以在 Ember.js 中轻松定义组件,并且每个组件的名称中都必须包含一个短横线。

2 组件生命周期

组件生命周期使用一些方法以便在组件生命周期的特定时间执行代码。

3 将属性传递给组件

组件不会直接访问模板范围内的属性。因此,只需在组件声明时声明属性即可。

4 在组件中包装内容

您可以使用模板在组件中包装内容。

5 自定义组件的元素

您可以使用 JavaScript 中的Ember.Component 子类自定义组件的元素,例如属性和类名。

6 使用块参数

传递给组件的属性可以在块表达式中返回结果。

7 处理事件

可以使用事件处理程序处理用户事件,例如双击、悬停、按键等。为此,请将事件名称应用为组件上的方法。

8 使用操作触发更改

组件可以使用操作触发更改并与事件进行通信。

EmberJS - 模型

模型是一个扩展 Ember Data 功能的类。当用户刷新页面时,页面的内容应由模型表示。在 Ember.js 中,每个路由都有一个关联的模型。模型有助于提高应用程序的性能。Ember Data 操纵服务器中存储的数据,并且可以轻松地与 socket.io 和 Firebase 或 WebSockets 等流式 API 协同工作。

核心概念

  • 存储
  • 模型
  • 记录
  • 适配器
  • 缓存

存储

存储是应用程序中所有可用记录的中央存储库和缓存。路由和控制器可以访问应用程序的存储数据。DS.Store 会自动创建,以便在整个对象之间共享数据。

import Ember from 'ember';

export default Ember.Route.extend ({
   model() {
      return this.store.find();
   }
});

模型

模型是一个扩展 Ember Data 功能的类,它指定与其他对象的关系。当用户刷新页面时,页面的内容应由模型表示。

import DS from 'ember-data';

export default DS.Model.extend ({
   owner: DS.attr(),
   city: DS.attr()
});

记录

记录是模型的一个实例,其中包含从服务器加载的信息,您可以通过其模型类型ID 来标识记录。

//It finds the record of type 'person' and an 'ID' of 1
this.get('store').findRecord('person', 1); // => { id: 1, name: 'steve-buscemi' }

适配器

适配器是一个对象,负责将 Ember 的请求记录转换为对特定服务器后端的适当调用。例如,如果您想查找 ID 为 1 的人,则 Ember 将使用 HTTP 作为/person/1 来加载 URL。

缓存

记录可以由存储自动缓存,当您第二次从服务器加载记录时,它会返回相同的对象实例。这提高了应用程序的性能,并尽可能快地向用户显示应用程序 UI。

下表列出了有关模型的详细信息:

序号 模型方式和说明
1 定义模型

模型是一个简单的类,它扩展了 Ember Data 的功能。

2 查找记录

您可以使用 Ember 数据存储检索记录。

3 创建和删除记录

您可以在模型实例上创建和删除记录。

4 关系

Ember.js 提供关系类型来指定模型如何相互关联。

5 将记录推入存储

您可以将记录推入存储的缓存中,而无需从应用程序请求记录。

6 处理元数据

元数据是用于特定模型或类型而不是使用记录的数据。

7 自定义适配器

Ember.js 适配器指定如何在后端数据存储中保存数据,例如 URL 格式和 REST API 标头。

EmberJS - 管理依赖项

Ember 使用 NPM 和 Bower 来管理依赖项,这些依赖项在 package.json 中为 NPM 定义,在bower.json 中为 Bower 定义。例如,您可能需要为样式表安装 SASS,但在开发 Ember 应用程序时 Ember 不会安装它。为此,请使用Ember Addons 来共享可重用的库。如果要安装任何 CSS 框架或 JavaScript 日期选择器依赖项,请使用 Bower 包管理器。

附加组件

可以使用以下命令使用Ember CLI 安装 Ember 附加组件:

ember install ember-cli-sass

ember install 命令会将所有依赖项保存到相应的配置文件。

Bower

它是一个 Web 包管理器,它管理 HTML、CSS、JavaScript 或图像文件的组件。它基本上维护和监控所有包并检查新的更新。它使用配置文件bower.json 来跟踪放置在 Ember CLI 项目根目录中的应用程序。

您可以使用以下命令安装项目依赖项:

bower install <dependencies> --save

资源

您可以将项目vendor/ 文件夹中的第三方 JavaScript(不是作为附加组件或 Bower 包提供的)以及项目public/ 文件夹中的自有资源(例如 robots.txt、favicon 等)放在一起。在开发 Ember 应用程序时 Ember 未安装的依赖项应使用清单文件ember-cli-build.js 包含。

AMD JavaScript 模块

您可以将资源路径作为第一个参数,将模块和导出列表作为第二个参数。您可以在ember-cli-build.js 清单文件中包含这些资源,如下所示:

app.import('bower_components/ic-ajax/dist/named-amd/main.js', {
   exports: {
      'ic-ajax': [
         'default',
         'defineFixture',
         'lookupFixture',
         'raw',
         'request'
      ]
   }
});

特定于环境的资源

可以通过将对象定义为第一个参数(这是一个环境名称)来在不同的环境中使用不同的资源,对象的 value 应在该环境中用作资源。在ember-cli-build.js 清单文件中,您可以包含如下内容:

app.import ({
   development: 'bower_components/ember/ember.js',
   production:  'bower_components/ember/ember.prod.js'
});

其他资源

将所有资源放置在public/ 文件夹中后,它们将被复制到 dist/ 目录中。例如,如果您复制放置在public/images/favicon.ico 文件夹中的 favicon,则它将被复制到dist/images/favicon.ico 目录中。第三方资源可以手动添加到vendor/ 文件夹中,也可以通过import() 选项使用 Bower 包管理器添加。未通过import() 选项添加的资源将不会出现在最终构建中。

例如,考虑以下代码行,它将资源导入到dist/ 文件夹中。

app.import('bower_components/font-awesome/fonts/fontawesome-webfont.ttf');

上面的代码行在dist/font-awesome/fonts/fontawesomewebfont.ttf 中创建了一个字体文件。您还可以将上面的文件放置在不同的路径中,如下所示:

app.import('bower_components/font-awesome/fonts/fontawesome-webfont.ttf', {
   destDir: 'assets'
});

它将字体文件复制到dist/assets/fontawesome-webfont.ttf

EmberJS - 应用程序关注点

可以使用Ember.Application 类扩展 Ember 应用程序,该类声明并配置有助于构建应用程序的对象。

应用程序在运行时创建Ember.ApplicationInstance 类,用于管理其各个方面,并充当实例化对象的拥有者。简而言之,Ember.Application 类定义了应用程序,而Ember.ApplicationInstance 类管理其状态。

下表列出了有关模型的更多详细信息:

序号 模型方式和说明
1 依赖注入

这是一个将一个对象的依赖项提供给另一个对象的流程,Ember 应用程序使用它来声明和实例化对象及其之间的依赖关系类。

2 初始化器

初始化器用于在应用程序启动时进行配置。

3 服务

服务是一个 Ember 对象,可以在应用程序的不同部分使用。

4 运行循环

这是应用程序大部分内部代码运行的区域。

EmberJS - 配置 Ember.js

Ember.js 可以配置为管理应用程序的环境。配置 Ember.js 包括以下主题:

序号 配置方法和描述
1 配置应用程序和 Ember CLI

您可以配置 Ember 应用程序和 CLI 来管理应用程序的环境。

2 禁用原型扩展和指定 URL 类型

可以通过将EXTEND_PROTOTYPES标志设置为 false 来禁用原型扩展,并使用 Ember 路由器选项指定 URL 类型。

3 嵌入应用程序和特性标志

您可以通过更改根元素将应用程序嵌入到现有页面中,并且可以根据项目的配置启用特性标志。

EmberJS - Ember 检查器

Ember inspector 是一个浏览器附加组件,用于调试 Ember 应用程序。Ember inspector 包括以下主题:

序号 Ember inspector 方法和描述
1 安装 Inspector

您可以安装 Ember inspector 来调试您的应用程序。

2 对象检查器

Ember inspector 允许与 Ember 对象进行交互。

3 视图树

视图树提供了应用程序的当前状态。

4 检查路由、数据选项卡和库信息

您可以看到 Inspector 定义的应用程序路由列表,数据选项卡用于显示模型类型的列表。

5 调试 Promise

Ember inspector 根据其状态提供 Promise。

6 检查对象和渲染性能

使用容器检查对象实例,并使用渲染性能选项计算应用程序的渲染时间。

广告