美文网首页ionic开发ionic3.0Web 前端开发
ionic3 教程(二)登录页制作

ionic3 教程(二)登录页制作

作者: Snorlax丶 | 来源:发表于2017-05-10 14:08 被阅读18256次

链接:
ionic3 教程(一)安装和配置
ionic3 教程(二)登录页制作
ionic3 教程(三)设置页制作
ionic3 教程(四)安卓硬件返回键处理
ionic3 教程(五)基本的网络请求

运行 platform 中 iOS 和 Android 项目,会发现一行警告,Not found www/index.html。

这是因为我们的上一次测试的页面是根目录中 src 的内容,需要把 src 路径下的内容同步过来。

// iOS
$ ionic cordova build ios
// Android
$ ionic cordova build android

// 执行完毕后可以去以下路径检查一下是否有html文件了

// iOS
platform/ios/www
// Android
platform/android/assets/www

有了内容之后,就可以在 Xcode 和 Android Studio 上运行项目了。

这里直我们做一个登录页面,了解一些基本知识。

1.修改 Tabs,让目录结构清晰

打开 Tabs.html,修改为如下代码:

<ion-tabs>
    <ion-tab *ngFor="let tabRoot of tabRoots" [root]="tabRoot.root" tabTitle="{{tabRoot.tabTitle}}" tabIcon="{{tabRoot.tabIcon}}"></ion-tab>
</ion-tabs>

打开 Tabs.ts,修改为如下代码:

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

import { AboutPage } from '../about/about';
import { ContactPage } from '../contact/contact';
import { HomePage } from '../home/home';

@Component({
  templateUrl: 'tabs.html'
})
export class TabsPage {
  tabRoots: Object[];

  constructor() {
    this.tabRoots = [
      {
        root: HomePage,
        tabTitle: 'Home',
        tabIcon: 'home'
      },
      {
        root: ContactPage,
        tabTitle: 'Contact',
        tabIcon: 'notifications'
      },
      {
        root: AboutPage,
        tabTitle: 'About',
        tabIcon: 'document'
      }
    ];
  }
}

这样你的目录结构就更加清晰了,方便以后为 Tabs 增加新的模块

2.新建登录页

// cd到项目目录,然后执行下面的代码
$ ionic g page login

该命令会自动生成这几个文件,如图

login.png

3.打开 app.module.ts

导入新生成的 Login

import { LoginPage } from '../pages/login/login';

并分别在加入 declarations 和 entryComponents 后面加入 LoginPage

我们所有新建的页面都需要在 module 进行声明才能使用

4.打开app.component.ts

import { LoginPage } from '../pages/login/login';

import 登录文件,并修改 rootPage 为 LoginPage

5.打开login.html文件,写入以下代码

<ion-header>
  <ion-navbar>
    <ion-title>登录</ion-title>
  </ion-navbar>
</ion-header>

<ion-content>
    <ion-item>
      <ion-label fixed>账号</ion-label>
      <ion-input type="text" placeholder="请输入账号" #username></ion-input>
    </ion-item>
    <ion-item>
      <ion-label fixed>密码</ion-label>
      <ion-input type="password" placeholder="请输入密码" #password></ion-input>
    </ion-item>
  <ion-item no-lines>
    <label item-right>记住密码</label>
    <ion-toggle></ion-toggle>
  </ion-item>

  <div style="text-align: center; margin-left: 30px; margin-right: 30px;">
    <button ion-button block color="danger" (click)="logIn(username, password)">
      登录
    </button>
  </div>
</ion-content>

效果如图所示,其中给 ion-item 加上 no-lines 可以去除底部的线条。(运行方式上一节已经讲过了)

登录.png

界面的样式会自动适配系统,这里安卓的标题会自动左对齐,解决的方法是在scss文件加入

.toolbar-title-md {
  text-align: center;
}

再举个例子,toggle 在安卓上会显示:

Android.png

iOS会显示:

iOS.png

颜色什么的当然可以改,相关的可以查阅官方文档。

仔细体会每一行代码,可以试着删掉一些元素来看看会发生什么改变。有人私聊问过我按钮怎么居中啊,怎么改变按钮宽度,这里直接上代码。

6.登录的实现

修改button的代码为:

<button ion-button block color="danger" (click)="logIn()">

并在login.ts中写下以下代码:

logIn() {
    alert('登录');
}

浏览器自动 build 之后,再次点击,就会弹出登录的提示框。这个logIn方法没有写权限修饰符,默认的话是 public 的。

这里有个问题,我们如何传值和验证。这里我给出一种简单的解决方案。这个 (click)="logIn()" 明显后面的括号里是可以传值的。我们修改代码如下

login.html
分别修改两个 input

<ion-input type="text" placeholder="请输入账号" #username></ion-input>
<ion-input type="password" placeholder="请输入密码" #password></ion-input>

将值传入 button 的点击事件

<button ion-button block color="danger" (click)="logIn(username, password)">

login.ts

修改logIn方法

logIn(username: HTMLInputElement, password: HTMLInputElement) {
    let userinfo: string = '用户名:' + username.value  + '密码:' + password.value;
    alert(userinfo);
}

这回你点击时候就会输出用户名和密码了。
同理,我们可以加上验证

logIn(username: HTMLInputElement, password: HTMLInputElement) {
    if (username.value.length == 0) {
        alert("请输入账号");
    } else if (password.value.length == 0) {
        alert("请输入密码");
    } else {
        let userinfo: string = '用户名:' + username.value + '密码:' + password.value;
        alert(userinfo);
    }
}

最后导入头文件,并实现跳转

import { TabsPage } from "../tabs/tabs";

在登录成功后面加入以下代码:

this.navCtrl.push(TabsPage);

测试一下,输出账号密码,点击登录即可跳转到 Tabs 页面。

Demo下载地址

相关文章

网友评论

  • _Coding:谢谢楼主,楼主辛苦了
  • 913abc69fdf1:www目录下的内容是用来干嘛的
    Snorlax丶:你的代码会被打包压缩放到 www 目录下。这个 www 目录会被放进 Android、iOS 项目中,在 MainActivity、MainViewController 中打开 www/index.html
  • 小辉煌阿:感谢楼主的分享!
  • d46c69aff841:楼主,界面可以上下滚动,需要怎么禁用呢?
  • 辣条o:您好。ionic serve运行项目之后,命令行那里已经是禁止输入状态了。如何再新建目录呀?
    _Coding:Ctrl+C+C可以退出服务;
  • 高冷的大白羊:你好,我想问一下对于解决键盘弹出页面上串这个问题,您是怎么解决的?
    Snorlax丶:@高冷的大白羊 自动上窜是为了防止键盘遮挡输入框吧,去官方文档看看 keyboard 相关的,应该有取消方法
  • e133f290eb95:请问,记住秘密的实现代码,怎么没有?能帮忙写一下嘛?
    e133f290eb95:记住密码按钮的实现代码,有嘛?
  • spilledyear:假如在 app.html 中有一个 menu绑定到了 <ion-nav>上,例如:
    <ion-menu [content]="content" id='app'>
    <ion-header></ion-header>

    <ion-content class="font-normal">
    <ion-list>
    <button ion-item *ngFor="let p of pages" (click)="openPage(p)">
    <p>{{p.title}}</p>
    </button>
    <button ion-item (click)="logout()">
    退出登录
    </button>
    </ion-list>
    </ion-content>
    </ion-menu>
    <ion-nav id="nav" [root]="rootPage" swipeBackEnabled="false"></ion-nav>

    那这时候登录界面怎么隐藏这个menu呢?或者说,登录界面怎么和别的界面区分开来呢

  • b41d3ee020d2:我登录的时候把用户名和密码都报错到了localstorage里面,第二次登录的时候在跟组件下面判断缓存,就是第二次登的时候有缓存直接进去主页,我在跟组件下面注册了NavController,但是还是报错找不到这个,是怎么回事啊,
  • zhuzhuzhu_8d56:我在你的最终成果中添加注册界面,但是总是提示没找不到/page/register,那两个ts文件我都加RegisterPage
  • 75afc06dcc73:✖ Running command - failed!
    [ERROR] An error occurred while running cordova build ios (exit code 1):
    这个错是怎么回事?
    只要build就有
  • 421ad736768c:能否加个联系方式。期待作者后续继续写作ionic的更多教程!!!
  • 421ad736768c:厉害,我算是入门了!!
  • 43d164787c85:你好,我按住你的配置,屏幕变成了空白,没有任何报错,就是一直空白,大神为什么呢
    小辉煌阿:@qzuser_b6cd 对,我也发现了,应该是把Tabspage给成Loginpage
    24b326586b23:第四步错了,是把Tabspage->Loginpage
  • d85cb7968272:测试一下,输出账号密码,点击登录即可跳转到 Tabs 页面,,,账号密码在那里设置??


    d85cb7968272: @devilx 大神,不行啊
    d85cb7968272:Runtime Error
    co.logIn is not a function
    TypeError: co.logIn is not a function
    at Object.eval [as handleEvent] (ng:///AppModule/LoginPage.ngfactory.js:472:24)
    at handleEvent (http://localhost:8100/build/vendor.js:12273:138)
    at callWithDebugContext (http://localhost:8100/build/vendor.js:13565:42)
    at Object.debugHandleEvent [as handleEvent] (http://localhost:8100/build/vendor.js:13153:12)
    at dispatchEvent (http://localhost:8100/build/vendor.js:9173:21)
    at http://localhost:8100/build/vendor.js:9765:20
    at HTMLButtonElement.<anonymous> (http://localhost:8100/build/vendor.js:33980:53)
    at t.invokeTask (http://localhost:8100/build/polyfills.js:3:9967)
    at Object.onInvokeTask (http://localhost:8100/build/vendor.js:4499:37)
    at t.invokeTask (http://localhost:8100/build/polyfills.js:3:9888)
    Snorlax丶:错了哈,是输入,页面出来之后。你把自己当用户,往 input 里随便输点东西就好了
  • d85cb7968272:大神,谢谢分享
  • a2e3ceffbb17:login.module.ts 这个文件是干嘛的?生成的时候,没有这个文件,好像是后来加进去的。
    a2e3ceffbb17:@devilx 是的,因为按照你的步骤一步一步的生成的,报错,然后把你的代码档下来,比对了一下,然后发现少了这个模板。加进去就好了。
    Snorlax丶:懒加载、应用模块化会用到。你看 App.module.ts 就是一个总的 module,比如应用有一个设置模块,可以单独建一个 module,把他子页面都写在 setting.module.ts 里,最后把 setting.module.ts 写到app.module.ts 的 imports 里就好了。官方怕新入门的用不明白,所以就取消自动生成了。
  • b176fde55567:第三步
    “3.打开 app.module.ts

    导入新生成的 Login

    import { LoginPage } from '../pages/login/login';
    并分别在加入 declarations 和 entryComponents 后面加入 LoginPage”

    这里 declarations 如果加入LoginPage的话 build android 会报错 显示和login.module.ts中的decalrations中 不知道您那里有没有这个现象
    Snorlax丶:@wuzp1230 对了,新版的 ionic 执行 ionic g page login。不会自动生成 module 文件,可能是因为你没有 module.ts 所以导致报错。你看看你有没有这个文件
    Snorlax丶:@wuzp1230 我的那个 Demo 运行是正常。会不会是一些配置问题,或者说咱们 ionic 的版本不同?你可以下载文章最下方的 Demo 看看。
    b176fde55567:显示和login.module.ts中的decalrations冲突

本文标题:ionic3 教程(二)登录页制作

本文链接:https://www.haomeiwen.com/subject/dcwwtxtx.html