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. Java导出pdf文件数据

    提示:导出pdf文件,需要3个jar包iText-2.1.5.jar,iTextAsian.jar,iText-rtf-2.1.4.jar. public boolean outputPdfJhsy( ...

  2. django-filter 实现过滤时查询是否包含在数组的方法,in数组的实现

    查了半天无解,还是在官网找到的,记录一下 使用 BaseInFilter 官网地址:https://django-filter.readthedocs.io/en/master/ref/filters ...

  3. Daemon 守护线程(27-11)

    t2.setDaemon(True)不再等待里面的sleep(5). 当设成setDaemon(True)这个线程就不等了. 例子一: import threadingfrom time import ...

  4. 能量项链 /// oj23800

    题目大意: N( 4 ≤ N ≤ 100 ),表示项链上珠子的个数 第二行是N个用空格隔开的正整数,所有的数均不超过1000. 第 i 个数为第 i 颗珠子的头标记( 1 ≤ i ≤ N ), 当 1 ...

  5. CSS——div内文字的溢出部分用省略号显示

    使得div内文字的溢出部分用省略号显示,可归纳为两种解决办法,一种方法是用CSS解决,另一种方法是js解决. 一.通过CSS控制显示 div内显示一行,超出部分用省略号显示 div内显示多行,超出部分 ...

  6. 洛谷P4027 [NOI2007]货币兑换

    P4027 [NOI2007]货币兑换 算法:dp+斜率优化 题面十分冗长,题意大概是有一种金券每天价值会有变化,你可以在某些时间点买入或卖出所有的金券,问最大收益 根据题意,很容易列出朴素的状态转移 ...

  7. escape encodeURI和encodeURIComponent的区别

    escape(与之对应->unescape) escape是对字符串(string)进行编码(而另外两种是对URL),作用是让它们在所有电脑上可读.编码之后的效果是%XX或者%uXXXX这种形式 ...

  8. [POI2014]KAR-Cards

    题目链接: 传送门 题目分析: 线段树妙题,感觉思路奇奇怪怪的,虽然对我来说不是"线段树菜题"(\(ldx\)神仙\(blog\)原话)\(QAQ\) 考虑怎么样维护可合并的信息解 ...

  9. System.Web.Mvc.FilePathResult.cs

    ylbtech-System.Web.Mvc.FilePathResult.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, Pub ...

  10. OpenCASCADE点向圆柱面投影

    OpenCASCADE点向圆柱面投影 eryar@163.com OpenCASCADE的类Extrema_ExtPElS提供了点到基本曲面的投影计算功能,距离可能是最大值或是最小值.如下图所示的点到 ...