Ionic login简单登录页面
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"> 用户名</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"> 密码</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>登 录</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"> 手机号</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"> 验证码</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>登 录</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简单登录页面的更多相关文章
- java web: eclipse & maven & jetty & struts2 & mysql = 简单登录页面
第一次接触java web开发,花费了一天半的时间,写了个简单的登录页面,以此文为记. 开发工具 Eclipse Luna Release (4.4.0) 已集成maven,maven目前的体会就是管 ...
- 一步一步理解 python web 框架,才不会从入门到放弃 -- 简单登录页面
上一节,我们基本了解了 Django 的一些配置,这一节,我们将通过一个简单的登录页面,进一步学习 Django 的使用. 新建项目 首先,新建一个 Django 项目,记得别弄错了哦. settin ...
- asp.net+mvc+easyui+sqlite 简单用户系统学习之旅(三)—— 简单登录页面+sqlite+动软代码生成器的使用
上一节讲到利用easyui的layout.tree.tab和datagrid创建用户管理的页面,注意利用到easyui的页面一定要按顺序添加jQuery和easyUI的.js和.css样式,灵活查看e ...
- (二)spring Security 自定义登录页面与校验用户
文章目录 配置 security 配置下 MVC 自定义登录页面 自定义一个登陆成功欢迎页面 效果图 小结: 使用 Spring Boot 的快速创建项目功能,勾选上本篇博客需要的功能:web,sec ...
- python web框架 Django 登录页面
在django 项目下 创建一个templates 放模板的文件夹 html文件都放在这里 在里面写一个login.html 登录页面 urls.py 加上 login 对应关系 from djang ...
- javaWeb简单登录实现验证数据库
用户登录案例需求: 1.编写login.html登录页面 username & password 两个输入框 2.使用Druid数据库连接池技术,操作mysql,day14数据库中user表 ...
- PHP实践项目【1】:注册登录页面
在我们这个项目里面,一共用到了5个php文件,他们分别是: login.php 登录页面 logincheck.php 登录检测php文件 register.php 新用户注册页面 regcheck. ...
- HTML5实战教程———开发一个简单漂亮的登录页面
最近看过几个基于HTML5开发的移动应用,比如臭名昭著的12036移动客户端就是主要使用HTML5来实现的,虽然还是有点反应迟钝,但已经比较流畅了,相信随着智能手机的配置越来越高性能越来越好,会越来越 ...
- vue_cli下开发一个简单的模块权限系统之建立登录页面并且实现在浏览器输入地址出现内容
新建一个Login.vue(登录页面,先把Hello.vue的内容复制过来即可) 然后我们打开router下面的index.js,第一个箭头:(引入vue路由)第二个箭头(引入我们新建的Login.v ...
随机推荐
- VC中编辑框更新SetDlgItemText()与UpdateData()的区别
SetDlgItemText(IDC_EDIT_RXDATA,m_strREData); //前一个是ID号,后一个是编辑框的成员变量 UpdateData(FALSE); 它们都能更新编辑框的 ...
- 关于css布局的定位问题
虽然职位说是PHP程序,但实际上什么都要做些,排版当然也免不了了,以前自己做网站时就能排出网页了,但是很多东西不系统,有点走马观花,例如关于这个css布局定位的问题就是,今天特意总结了一下,知识这东西 ...
- SpringBoot-application:application.yml/配置文件详解
ylbtech-SpringBoot-application:application.yml/配置文件详解 springboot采纳了建立生产就绪spring应用程序的观点. Spring Boot优 ...
- linux大神
http://blog.csdn.net/skykingf/article/category/780616
- PyCharm中批量查找及替换
选中需要操作的字符 Ctrl + R 替换 Ctrl + Shift + F 全局查找 Ctrl + Shift + R 全局替换 源自: PyCharm中批量查找及替换 - Ella_Wu - 博客 ...
- day 67 Django基础三之视图函数
Django基础三之视图函数 本节目录 一 Django的视图函数view 二 CBV和FBV 三 使用Mixin 四 给视图加装饰器 五 Request对象 六 Response对象 一 Dja ...
- CSS 实现自适应正方形
在处理移动端页面时,我们有时会需要将banner图做成与屏幕等宽的正方形以获得最佳的体验效果,比如,商品详情页, 方法1.CSS3 vw单位 CSS3 中新增了一组相对于可视区域百分比的长度单位 vw ...
- springcloud(十五):服务网关zuul
前面的文章我们介绍了,Eureka用于服务的注册于发现,Feign支持服务的调用以及均衡负载,Hystrix处理服务的熔断防止故障扩散,Spring Cloud Config服务集群配置中心,似乎一个 ...
- COGITATE | 分析当前热门软件的创新
热门软件分析实例一——Github [简介] gitHub是一个面向开源及私有软件项目的托管平台,因为只支持git 作为唯一的版本库格式进行托管,故名gitHub.作为一个分布式的版本控制系统,在Gi ...
- webservice、httpClient、dubbo的区别
在开发中,对于同一个war包中的对象方法我们可以直接调用,但是很多情况下需要在不同项目或者不同服务器进行相互调用 webservice webservice技术可以实现不同服务器项目直接的调用和交换数 ...