在本系列的第一部分中,我们了解了如何开始使用 angularjs 和 firebase 创建应用程序。我们创建了登录页面,并使用 firebase 作为后端实现了登录功能。
在本教程中,我们将把本系列提升到一个新的水平。我们将创建并设置注册页面,并了解如何在 angularjs 中进行表单验证。
开始使用让我们首先从 github 克隆本教程的第一部分。
git clone https://github.com/jay3dec/angularjs_firebase_part1.git
获取代码后,导航到项目目录并安装所需的依赖项。
cd angularjs_firebase_part1npm install
安装所有依赖项后,启动服务器。
npm start
将浏览器指向 http://localhost:8000/app/#/home,应用程序应该正在运行。
创建注册屏幕我们将首先创建一个页面供访客用户注册。导航到 angularjs_firebase_part1/app 并创建一个名为 register 的文件夹。在 register 文件夹中,创建 register.html 和 register.js 文件。以下是 register.html 的外观:
<!doctype html><html lang=en><head> <meta http-equiv=content-type content=text/html; charset=utf-8> <link rel=icon href=http://getbootstrap.com/favicon.ico> <title>angularjs & firebase web app</title> <link href=http://getbootstrap.com/dist/css/bootstrap.min.css rel=stylesheet> <link href=http://getbootstrap.com/examples/signin/signin.css rel=stylesheet> <link href=justified-nav.css rel=stylesheet></head><body> <div class=container> <div class=jumbotron style=padding-bottom:0px;> <h2>angularjs & firebase app!</h2> </div> <form class=form-signin role=form> <input type=email class=form-control placeholder=email address required= autofocus=> <input type=password class=form-control placeholder=password required=> <label class=checkbox> <a href=#> sign in</> </label> <button type=button class=btn btn-lg btn-primary btn-block>register</button> </form> </div></body></html>
如上面的 html 代码所示,我们使用 bootstrap 进行 html 设计。
在 register.js 中,我们将声明应用程序访问注册视图的路由。 $routeprovider 有一个名为 when 的方法,我们将使用该方法为注册视图创建路由。定义新路由时,我们将设置一个 templateurl ,它将在 index.html 中呈现。除此之外,我们还将为注册视图中新创建的 $scope 设置一个 控制器。控制器是控制特定视图的逻辑。它应该是这样的:
'use strict';angular.module('myapp.register', ['ngroute'])// declared route .config(['$routeprovider', function($routeprovider) { $routeprovider.when('/register', { templateurl: 'register/register.html', controller: 'registerctrl' });}])// register controller.controller('registerctrl', [function() {}]);
现在打开 app.js 并将注册模块 myapp.register 添加到应用中。
'use strict';angular.module('myapp', [ 'ngroute', 'myapp.home', 'myapp.register' // newly added register route]).config(['$routeprovider', function($routeprovider) { // set defualt view of our app to home $routeprovider.otherwise({ redirectto: '/home' });}]);
要显示注册页面,我们需要在应用的主 html 模板文件中包含 register.js。打开 index.html 并包含以下内容:
<script src=register/register.js></script>
重新启动服务器并将浏览器指向http://localhost:8000/app/index.html#/register,您应该会看到注册屏幕:
接下来,让我们将注册屏幕链接到登录屏幕。在home.html和register.html中分别有一个sign up和sign in href。我们将设置两个 href 源,以便可以从两个页面访问它们。
在 home.html 中:
<a href=#/register> sign up<a/>
在 register.html 中:
<a href=#/home> sign in<a/>
angularjs 中的表单验证当用户在注册屏幕上输入其电子邮件地址和密码时,我们需要验证一些内容。首先,输入的电子邮件 id 应该具有有效的电子邮件 id 格式,其次,输入的密码应该具有最小长度。
angularjs 提供了 formcontroller,它可以跟踪表单内的每个元素。来自 angularjs 文档:
formcontroller 跟踪其所有控件和嵌套表单以及它们的状态,例如有效/无效或脏/原始。
formcontroller 有一些属性,例如 $pristine, $dirty, $invalid, $valid 等。我们将了解这些属性是什么,并且我们将使用其中一些属性来为我们的注册页面实现表单验证。
首先,我们需要修改表单 html 以添加验证消息。在 register.html 中修改表单 html,如图所示。
<form class=form-signin name=regform> <div class=form-group> <label>email</label> <input type=email name=email class=form-control ng-model=user.email> <p>enter a valid email.</p> </div> <div class=form-group> <label>password</label> <input type=password name=password class=form-control ng-model=user.password> <p>min password length is 8 characters.</p> </div> <button type=button class=btn btn-lg btn-primary btn-block>register</button></form>
保存更改,重新启动服务器,然后刷新 register 页面。您应该看到如下页面:
现在,正如我们在上面的屏幕中看到的,验证消息是可见的。仅当电子邮件和密码无效时,我们才需要显示它们。
angularjs 提供了一个名为 ngshow 的指令来根据特定的表达式显示 html。 (angularjs 指令是 angularjs 提供的扩展 html 属性,用于增强元素的功能。)因此,当输入电子邮件包含无效数据时,我们将使用 ngshow 显示验证消息。但我们如何知道输入的电子邮件是否无效呢?好吧,请记住我们之前讨论过的 formcontroller 属性。 formcontroller 有一个名为 $invalid 的属性,如果控件无效,则该属性为 true。如果输入的电子邮件无效,则 regform.email.$invalid 将为 true。因此,我们将使用 $invalid 和 ngshow 来显示验证消息。修改电子邮件消息范围,如下所示:
<p ng-show=regform.email.$invalid>enter a valid email.</p>
保存更改,重新启动服务器,然后浏览到注册页面。您会看到电子邮件 id 的验证消息不再显示。现在,尝试在输入电子邮件中输入一些数据,将会弹出错误消息。尝试输入有效的电子邮件地址,验证消息将会消失。但最初仍然显示密码最小长度的消息。让我们修复它。
angularjs 提供了另一个名为 ng-minlength 的指令来设置任何输入控件的最小长度。我们将使用它来设置密码字段的最小长度,然后使用 ngshow 来显示/隐藏验证消息。修改密码字段以包含 ng-minlength 指令,如下所示:
<input type=password name=password class=form-control ng-model=user.password ng-minlength=8>
接下来修改密码字段的验证消息范围,如下所示:
<p ng-show=regform.password.$error.minlength>min password length is 8 characters.</p>
因此,如果密码字段的最小长度不符合密码输入字段中设置的最小长度,则 regform.password.$error.minlength 将设置为“true”并且将会显示验证消息。
保存所有更改,重新启动服务器,然后浏览至注册页面。尝试输入密码值,验证消息将显示,直到密码长度为 8。
现在,为了突出显示无效的输入元素,我们可以使用一些样式。使用名为 ngclass 的 angularjs 指令,我们可以使用 $invalid 属性动态突出显示错误的输入元素。因此,将 ngclass 指令添加到电子邮件和密码元素的父 div 中。
<div class=form-group ng-class={ 'has-error' : regform.email.$invalid }> <label>email</label> <input type=email name=email class=form-control ng-model=user.email> <p class=help-block ng-show=regform.email.$invalid>enter a valid email.</p></div><div class=form-group ng-class={ 'has-error' : regform.password.$invalid }> <label>password</label> <input type=password name=password class=form-control ng-model=user.password ng-minlength=8> <p class=help-block ng-show=regform.password.$error.minlength>min password length is 8 characters.</p></div>
保存更改,重新启动服务器,然后尝试浏览到注册页面。现在,对于无效条目,验证消息将显示如下:
现在,正如您在上面的屏幕中看到的,在验证错误时, register 按钮是已启用。除非输入的电子邮件和密码有效,否则我们将其禁用。 angularjs 提供了一个名为 ngdisabled 的指令,它有助于根据表达式禁用元素。如果 email 和 password 已验证,则将设置 user.email 和 user.password 模型。因此,我们将使用这两个对象通过 ngdisabled 来启用/禁用注册按钮。修改注册按钮html,如图:
<button type=button ng-disabled=!user.email || !user.password class=btn btn-lg btn-primary btn-block>register</button>
如您所见,如果 user.email 或 user.password 不为 false,则 ng-disabled 将为 true,这将是仅当数据无效时才出现这种情况。
保存所有更改,重新启动服务器,并刷新注册页面。您会注意到,“注册”按钮已被禁用,并且在输入有效的电子邮件地址和密码之前将一直保持禁用状态。
验证登录屏幕在登录屏幕上实施验证的方式与我们在注册屏幕上实施的方式非常相似。我建议您自己对登录屏幕实施验证作为练习。如果您遇到困难,请查看 登录 表单的修改后的 html 代码(位于 home.html 中,如下所示:
)<form class=form-signin name=signinform role=form> <div class=form-group ng-class={ 'has-error' : signinform.email.$invalid }> <label>email</label> <input type=email name=email class=form-control ng-model=user.email> <p class=help-block ng-show=signinform.email.$invalid>enter a valid email.</p> </div> <div class=form-group ng-class={ 'has-error' : signinform.password.$invalid }> <label>password</label> <input type=password name=password class=form-control ng-model=user.password ng-minlength=3> <p class=help-block ng-show=signinform.password.$error.minlength>min password length is 8 characters.</p> </div> <label class=checkbox> <a href=#/register> sign up</a> </label> <button ng-disabled=!user.email || !user.password type=button ng-click=signin($event) class=btn btn-lg btn-primary btn-block>signin</button></form>
总结在本教程的这一部分中,我们创建了注册页面并为其设置了路由。我们还了解了如何使用 angularjs 为注册页面实现验证。
在下一部分中,我们将重点关注实现注册功能和一些其他功能。上述教程的源代码可在 github 上获取。
请在下面的评论中告诉我们您的想法!
以上就是继续旅程:从头开始使用 angularjs 和 firebase 构建 web 应用程序:第 2 部分的详细内容。