1.login.html

 <ion-view view-title="登录" hide-nav-bar="true">
<div class="bar bar-header bar-positive ">
<h1 class="title">登录</h1>
<button class="button button-clear" ng-click="registerclick()">注册</button>
</div>
<div class="bar bar-subheader">
<ion-scroll direction="x" scrollbar-x="false" overflow-scroll="true" style="overflow: hidden">
<div class="button-bar sub_header_list">
<a class="button button-clear {{isgeneralCss}}" ng-click="changeModel(0)">普通登录</a>
<a class="button button-clear {{isfastCss}}" ng-click="changeModel(1)">快捷登录</a>
</div>
</ion-scroll>
</div>
<ion-content class="has-subheader"> <form name="myForm" ng-show="isloginModel" ng-submit="signIn()">
<div class="list list-inset removePM">
<label class="item item-input">
<span class="input-label ion-android-people">&nbsp;&nbsp;用户名</span>
<input type="text" name="txtUserName" placeholder="请输入用户名" ng-model="user.username" required>
</label>
<label class="item item-input">
<span class="input-label ion-android-lock">&nbsp;&nbsp;密码</span>
<input type="password" name="txtPwd" placeholder="请输入密码" ng-model="user.password" required>
</label>
</div>
<div class="row list-borderless">
<div class="col col-67"><ion-checkbox ng-model="user.isChecked">是否记住密码</ion-checkbox> </div>
<div class="col col-center"><a href="#">忘记密码?</a></div>
</div> <div class="padding">
<button class="button button-block button-positive" type="submit" ng-disabled=" myForm.txtUserName.$invalid || myForm.txtPwd.$invalid">
<b>登&nbsp;&nbsp;录</b>
</button>
</div>
</form> <form name="myfastForm" ng-show="!isloginModel" ng-submit="signIn()">
<div class="list list-inset removePM">
<label class="item item-input">
<span class="input-label ion-android-people">&nbsp;&nbsp;手机号</span>
<input type="text" name="txtphone" placeholder="请输入手机号" ng-model="user.phone" required>
</label>
<label class="item item-input">
<span class="input-label ion-android-lock">&nbsp;&nbsp;验证码</span>
<input type="text" name="txtvercode" style="flex:120px;" placeholder="请输入验证码" ng-model="user.vercode" required>
<button class="button" style="font-size:12px; color:red;">获取验证码</button>
</label>
</div> <div class="padding">
<button class="button button-block button-positive" ng-disabled="myfastForm.txtphone.$invalid || myfastForm.txtvercode.$invalid">
<b>登&nbsp;&nbsp;录</b>
</button>
</div>
<div class="padding com">
<span class="positive">点击登录表明你已同意并阅读<a style="color:red; " href="#">《快捷登录条款》</a></span>
</div>
</form>
</ion-content>
</ion-view>

2.controller.js

   //用户登录
.controller('LoginCtrl', function ($scope, $state, $ionicLoading, userFactory, Storage) { $scope.user = {
username: "",
password: "",
isChecked: false,
phone: '',
vercode:''
}
$scope.$on('$stateChangeSuccess', function () {
if (Storage.get("loginInfo") != null) {
$scope.user.username = Storage.get("loginInfo").username;
$scope.user.password = Storage.get("loginInfo").password;
$scope.user.isChecked = Storage.get("loginInfo").isChecked;
}
else {
$scope.user.username = "";
$scope.user.password = "";
$scope.user.isChecked = false;
}
}); //登录
$scope.signIn = function () { userFactory.login($scope.user.username, $scope.user.password);
} $scope.$on('User.loginUpdated', function () {
console.log("User.loginUpdated");
var userRel = userFactory.getCurrentUser();
console.log(userRel);
if (userRel.status != "") {//登陆失败
$ionicLoading.show({
noBackdrop: true,
template: userRel.msg,
duration:
});
} else {
if ($scope.user.isChecked) {
Storage.set("loginInfo", $scope.user);
} else {
Storage.remove("loginInfo");
}
$state.go('app.user'); //路由跳转 }
}); //登录切换
$scope.isloginModel = true;
$scope.isgeneralCss = "sub_button_select";
$scope.isfastCss = "";
$scope.changeModel = function (lm) { if (lm == ) {
$scope.isgeneralCss = "sub_button_select";
$scope.isloginModel = true;
$scope.isfastCss = "";
}
if (lm == ) { $scope.isgeneralCss = "";
$scope.isfastCss = "sub_button_select";
$scope.isloginModel = false;
}
}
$scope.registerclick = function () {
$state.go("register");
}
})

3.services.js

 .factory('userFactory', function ($resource, $rootScope, ENV, Storage, $http, $q) {
var user = {}; //返回用户对象 return {
//登录
login: function (username, password) {
$http.get("http://192.168.0.109:8004/api/" + "/Login/Loging", { params: { UserName: username, Password: password} })
.success(function (response) {
console.log("Loging调用成功")
var json = eval('(' + response + ")");
user = json;
console.log(json.userInfo); if (json.status == "") {
Storage.set("UserKey", json.userInfo);
}
$rootScope.$broadcast('User.loginUpdated');
}).error(function (err, status) {
$ionicLoading.show({
noBackdrop: true,
template: err,
duration:
});
});
},
getCurrentUser: function () {
return user;
}
};
})
.factory('Storage', function ($state, ENV, $http, $rootScope) {
var version = "";
return {
set: function (key, data) {
return window.localStorage.setItem(key, window.JSON.stringify(data));
},
get: function (key) { return window.JSON.parse(window.localStorage.getItem(key));
},
remove: function (key) {
return window.localStorage.removeItem(key);
}
};
})

css:

.bar .sub_header_list .button.button-clear{

  border-bottom: 1px solid #eee;
}
.sub_header_list{
width: 100%;
}
.sub_header_list .button{
width: 50%;
color:#666;
}
.bar .sub_header_list .button.sub_button_select{
border-bottom:2px solid #387ef5;
position:relative;
}
.bar-subheader{
border-bottom: none;
}

效果图:

Ionic login简单登录页面的更多相关文章

  1. java web: eclipse & maven & jetty & struts2 & mysql = 简单登录页面

    第一次接触java web开发,花费了一天半的时间,写了个简单的登录页面,以此文为记. 开发工具 Eclipse Luna Release (4.4.0) 已集成maven,maven目前的体会就是管 ...

  2. 一步一步理解 python web 框架,才不会从入门到放弃 -- 简单登录页面

    上一节,我们基本了解了 Django 的一些配置,这一节,我们将通过一个简单的登录页面,进一步学习 Django 的使用. 新建项目 首先,新建一个 Django 项目,记得别弄错了哦. settin ...

  3. asp.net+mvc+easyui+sqlite 简单用户系统学习之旅(三)—— 简单登录页面+sqlite+动软代码生成器的使用

    上一节讲到利用easyui的layout.tree.tab和datagrid创建用户管理的页面,注意利用到easyui的页面一定要按顺序添加jQuery和easyUI的.js和.css样式,灵活查看e ...

  4. (二)spring Security 自定义登录页面与校验用户

    文章目录 配置 security 配置下 MVC 自定义登录页面 自定义一个登陆成功欢迎页面 效果图 小结: 使用 Spring Boot 的快速创建项目功能,勾选上本篇博客需要的功能:web,sec ...

  5. python web框架 Django 登录页面

    在django 项目下 创建一个templates 放模板的文件夹 html文件都放在这里 在里面写一个login.html 登录页面 urls.py 加上 login 对应关系 from djang ...

  6. javaWeb简单登录实现验证数据库

    用户登录案例需求: 1.编写login.html登录页面 username & password 两个输入框 2.使用Druid数据库连接池技术,操作mysql,day14数据库中user表 ...

  7. PHP实践项目【1】:注册登录页面

    在我们这个项目里面,一共用到了5个php文件,他们分别是: login.php 登录页面 logincheck.php 登录检测php文件 register.php 新用户注册页面 regcheck. ...

  8. HTML5实战教程———开发一个简单漂亮的登录页面

    最近看过几个基于HTML5开发的移动应用,比如臭名昭著的12036移动客户端就是主要使用HTML5来实现的,虽然还是有点反应迟钝,但已经比较流畅了,相信随着智能手机的配置越来越高性能越来越好,会越来越 ...

  9. vue_cli下开发一个简单的模块权限系统之建立登录页面并且实现在浏览器输入地址出现内容

    新建一个Login.vue(登录页面,先把Hello.vue的内容复制过来即可) 然后我们打开router下面的index.js,第一个箭头:(引入vue路由)第二个箭头(引入我们新建的Login.v ...

随机推荐

  1. thinkphp 获取模板地址

    为了更方便的输出模板文件,新版封装了一个T函数用于生成模板文件名. 用法: 大理石平台检验标准 T([资源://][模块@][主题/][控制器/]操作,[视图分层]) T函数的返回值是一个完整的模板文 ...

  2. Git中.gitignore忽略规则

    # 此为注释 – 将被 Git 忽略 *.a # 忽略所有 .a 结尾的文件 !lib.a # 但 lib.a 除外 /TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TO ...

  3. Hibernate之Inverse的用法

    在多的一端配置Inverse设置为true,来自动管理关系

  4. System.Drawing.Image.cs

    ylbtech-System.Drawing.Image.cs 1.程序集 System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyTok ...

  5. Python中%r和%s的详解及区别_python_脚本之家

    Python中%r和%s的详解及区别_python_脚本之家 https://www.jb51.net/article/108589.htm

  6. PAT甲级——A1127 ZigZagging on a Tree【30】

    Suppose that all the keys in a binary tree are distinct positive integers. A unique binary tree can ...

  7. spring boot发简单文本邮件

    首先要去邮箱打开POP3/SMTP权限: 然后会提供个授权码,用来发送邮件.忘记了,可以点生成授权码再次生成. 1.引入spring boot自带的mail依赖,这里版本用的:<spring-b ...

  8. mysql 表查询结果 总行数计算

    一般的查询语句是这样的 SELECT  id,name FROM SystemEvents WHERE  1=1 limit 9,10 SELECT  * FROM SystemEvents WHER ...

  9. 【9.14NOIP模拟pj】wtaxi 题解

    [9.14NOIP模拟pj]wtaxi 搜索

  10. Duilib 入门教程: 怎么创建一个自定义的窗口

    一直想找一个好用UI 界面库,看过Direct UI,也想过 金山的界面库,后来找到了这个Duilib 现在的软件界面很多都是利用XML 来布局和定位. 像迅雷7,QQ,金山卫士等 [html] vi ...