knockout+bootstrap+MVC 登录页实现
一、环境概述
1、MVC4.0项目
2、bootstrap引入:
- 生产环境版本引入:在web\Content 文件夹中引入bootstrap-3.2.0-dist,
- 源码版本CSS引入:将bootstrap-3.2.0\docs\examples中的所有css复制到Web\Content\bootstrap-3.2.0-dist\css\themes
3、KnockoutJS引入:
- 将knockout-3.2.0.js文件引入到Web\scripts
4、JQuery引入
二、前端CSHTML
<div class="container">
<div class="form-signin">
<h2 class="form-signin-heading">Please sign in</h2>
<input type="email" data-bind="value:accountName" autofocus="" required="" placeholder="Email address" class="form-control">
<input type="password" data-bind="value:password" required="" placeholder="Password" class="form-control">
<div class="row">
<div class="col-sm-7">
<input type="email" data-bind="value:verifyCode" autofocus="" required="" placeholder="Email address" class="form-control">
</div>
<div class="col-sm-3">
<img height=" title="点击刷新验证码" data-bind="attr: { 'src': verifyimageSrc },click:ImageOnClick" />
</div>
</div>
<div class="checkbox">
<label>
<input type="checkbox" value="remember-me" data-bind="checked:isRemember"> Remember me
</label>
</div>
<input type="button" class="btn btn-lg btn-primary btn-block"
data-bind="click:submit" value="Sign in"/>
</div>
</div>
<script src="/scripts/jquery-2.1.1.min.js"></script>
<script src="/scripts/knockout-3.2.0.js"></script>
<script src="/scripts/Account/Login.js"></script>
<script src="/Content/bootstrap-3.2.0-dist/js/bootstrap.min.js"></script>
<link href="/Content/bootstrap-3.2.0-dist/css/bootstrap.min.css" rel="stylesheet" />
<link href="/Content/bootstrap-3.2.0-dist/css/themes/signin.css" rel="stylesheet" />
三、Login.js:
var ViewModel = function () {
//获取当前网址,如: http://localhost:8080/ems/Pages/Basic/Person.jsp
var curWwwPath = window.document.location.href;
//获取主机地址之后的目录,如: /ems/Pages/Basic/Person.jsp
var pathName = window.document.location.pathname;
var pos = curWwwPath.indexOf(pathName);
//获取主机地址,如: http://localhost:8080
, pos);
var ImageNewPath = "/tool/verifyimage?time=";
var newDate = new Date();
var self = this;
self.accountName = ko.observable("");
self.password = ko.observable("");
self.verifyCode = ko.observable("");
self.isRemember = ko.observable("");
self.verifyimageSrc = ko.observable("");
GetImage(newDate, ImageNewPath, self);
self.ImageOnClick = function () {
newDate = new Date();
GetImage(newDate, ImageNewPath, self);
}
self.submit = function (Student) {
$.post("/account/login",
{
accountName: self.accountName(),
password: self.password(),
verifyCode: self.verifyCode(),
sisRemember: self.isRemember(),
verifyimageSrc: self.verifyimageSrc(),
},
function (data) {
alert("Data Loaded: " + data.Data);
});
};
}
var GetImage = function (Date, ImageNewPath, KoObject) {
$.get(
"../tool/verifyimage",
{ time: Date },
function (data) {
KoObject.verifyimageSrc(ImageNewPath + Date);
}
);
}
$(document).ready(function () {
ko.applyBindings(ViewModel);
});
knockout+bootstrap+MVC 登录页实现的更多相关文章
- 后台跳转到登录页嵌套在iframe的问题(MVC例)
//首页 public ActionResult Index() { if (!Request.IsAuthenticated) //判断权限,没有登录就跳回登录页 {string url = Url ...
- Asp.net MVC访问框架页中嵌套的iframe页面时,如果session或cookie过期,登录验证超时怎样自动跳转到登录页
一般登录验证的过滤器中,使用验证过滤器的Redirect方法,将请求重定向到指定的URL.但是如果我们要访问的页面是一个嵌套在框架页中的iframe页面时,这种重定向只会对iframe页面凑效,也就是 ...
- Spring Security笔记:自定义登录页
以下内容参考了 http://www.mkyong.com/spring-security/spring-security-form-login-example/ 接上回,在前面的Hello Worl ...
- 通过ajax前端后台交互/登录页和注册页前端后台交互详解/前端后台交互基础应用/几个后台函数的基础应用/php文件函数基础应用/php字符传函数基础应用/php数组函数基础应用
前 言 PHP 学习了好久的PHP,今天做一个可以后台交互的登录页和注册页,没做什么判断,简单的了解一下. 具体的内容分析如下: ① PHP中的数据传输-->>由注册页传输 ...
- [转载:Q1mi]Bootstrap和基于Bootstrap的登录验证示例
转载自:Q1mi Bootstrap介绍 Bootstrap是Twitter开源的基于HTML.CSS.JavaScript的前端框架. 它是为实现快速开发Web应用程序而设计的一套前端工具包. 它支 ...
- SSM登录跳转到登录页,登录页不能加载js和样式
SSM登录跳转到登录页,登录页不能加载js和样式选用jsppage添加根路径. <% String rootPath = request.getContextPath(); %> < ...
- 授权过期后AJAX操作跳转到登录页的一种全局处理方式
前两天园友JustRun分享了一篇 <菜鸟程序员之Asp.net MVC Session过期异常的处理>博文,正好自己前段时间被安排处理过这个问题,发现JustRun的方法有一点点可优化的 ...
- MVC 登录后重定向回最初请求的 URL FormsAuthentication.RedirectFromLoginPage
在传统的Asp.net webForm 中如果使用 Form身份验证.登录后重定向到最初请求的页面只需使用 FormsAuthentication.RedirectFromLoginPage 但在MV ...
- .Net MVC 标签页
目录 Bootstrap的标签页 适合.Net MVC的标签页 Bootstrap的标签页 下面是Bootstrap的标签页,挺好的,但是用的id,内容是固定的?我不知道怎么变成不同的视图来 < ...
随机推荐
- Technology Remarks
-----------------------分隔符-----12.10.2016------ 抓视频 关键字补充: Base64编码/解码 出现这样的情况怎么办呢? 网址: abook-hep ...
- PHP 二维码解码 (读取二维码)
#zbar wget http://ncu.dl.sourceforge.net/project/zbar/zbar/0.10/zbar-0.10.tar.bz2 yum install gtk2 g ...
- 读<jquery 权威指南>[1]-选择器及DOM操作
今天是小年了,2013马上要过去了,但是学习不能间断啊.最近正在看<jQuery权威指南>,先温习一下选择器和DOM操作. 一.基本选择器 1.table单双行: $(function ( ...
- BZOJ1778 [Usaco2010 Hol]Dotp 驱逐猪猡
首先我们列出转移矩阵$M$,$M_{i, j} = \frac {1 - \frac{p} {q}} {deg[i]}$(i,j之间有边)or $M_{i, j} = 0$(i,j之间没边) 则这个矩 ...
- Launch Screen在iOS7/8中的实现
Launch Screen在iOS7/8中的实现 目前项目中需要解决的问题是: 兼容iOS7和iOS8,之前的版本不需要支持了 实现兼容3.5.4.4.7和5.5寸屏幕,竖屏的Lauch Screen ...
- css属性选择器
1.E[att] 选择具有attr属性的E元素.2.E[att="val"] 选择具有att属性且属性值等于val的E元素3.E[att~="val"] 选择具 ...
- SQL Server存储过程Return、output参数及使用技巧
SQL Server目前正日益成为WindowNT操作系统上面最为重要的一种数据库管理系统,随着 SQL Server2000的推出,微软的这种数据库服务系统真正地实现了在WindowsNT/2000 ...
- bzoj 2875: [Noi2012]随机数生成器
#include<cstdio> #include<iostream> #include<cstring> #define ll long long using n ...
- Visual Studio 拓展插件——Image Optimizer
一句话概括效用:在Visual Studio的解决方案中,为图片或包含图片的文件夹添加右键菜单,可对图片进行压缩,无损压缩. 在VS扩展工具中安装 安装好后在VS资源管理器中选择图片右键,在右键菜单中 ...
- Python开发入门与实战11-单元测试
11. 单元测试 本章节我们来讲讲django工程中如何实现单元测试,单元测试如何编写以及在可持续项目中单元测试的重要性. 下面是单元测试的定义: 单元测试是开发者编写的一小段代码,用于检验被测代码的 ...