JQuery遮罩层登录界面实现(AJAX实现登录验证,源码下载)

news/2024/7/4 0:53:35 标签: jquery, ajax, textbox, function, class, asp
class="baidu_pl">
class="article_content clearfix">
class="htmledit_views">

操作系统:Windwos7 Ultimate

开发工具:Visual Studio 2010

数据库:Sql Server 2005

测试浏览器:IE8、FF3.6.8、Google Chrome (IE8中弹出登录层后会出现竖拉条,其他两种没有出现,那个竖拉条可以在JS中通过修改数值让其不出现,但是下面会出现白边,越来越觉得IE有点那个了......)

1、预览

    1)登录前 

 

    2)点击登录显示登录窗口(层) ,同时用一个灰色透明层遮罩主窗体内容,点击【登录】,隐藏【登录】,显示loading图,登录失败,显示【登录】,隐藏登录图,同时显示提示信息

 

    3)登录成功后,去掉去掉遮罩层和登录层,显示“xxx,您好! ”

 

2、实现

     使用VS2010创建一个Web Site,此功能是在母版页Site.master中实现的。VS2010会自动添加JQuery的js文件到Scripts文件夹,并创建一个母版页和基于此母版页的Default.aspx和About.aspx两个窗体。

    1)登录层界面设计,看Site.master中的代码

class="language-html">Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/--><%@ Master Language="C#" AutoEventWireup="true" CodeFile="Site.master.cs" Inherits="SiteMaster" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head runat="server">
    <title>FlyNoteBook</title>
    <script src="Scripts/class="tags" href="/tags/JQUERY.html" title=jquery>jquery-1.4.1.min.js" type="text/javascript"></script>
    <script type="text/javascript" src="Scripts/common.js"></script>
    <link href="~/Styles/Site.css" rel="stylesheet" type="text/css" />
    <script type="text/javascript" src="Scripts/login.js"></script>
    <asp:ContentPlaceHolder ID="HeadContent" runat="server">
    </asp:ContentPlaceHolder>
</head>
<body>
    <form runat="server">
    <div class="page">
        <div class="header">
            <div class="title">
                  <img src="Images/Pictures/logo3.png" alt="FlyNoteBook Logo" />
                 FlyNoteBook
            </div>
            <div class="loginDisplay">
                <span id="popup" runat="server">登录</span>
                <span id="loginSuccess" runat="server"></span>
            </div>
            <div class="clear hideSkiplink">
                <asp:Menu ID="NavigationMenu" runat="server" CssClass="menu" EnableViewState="false"
                    IncludeStyleBlock="false" Orientation="Horizontal">
                    <Items>
                        <asp:MenuItem NavigateUrl="~/Default.aspx" Text="首页" />
                        <asp:MenuItem NavigateUrl="~/About.aspx" Text="关于" />
                    </Items>
                </asp:Menu>
            </div>
        </div>
        <!--登录窗口:Begin-->
        <div id="divLoginWindow">
            <table style="width: 100%;" border="0" cellpadding="2" cellspacing="0">
                <tr style="background-color: #e0f3d9; border-bottom: #bfe5b3 solid 2px">
                    <td style="height: 38px; width: 100px;">
                         用户登录
                    </td>
                    <td>
                        <img src="Images/Button/close.gif" id="closeBtn" align="absmiddle" alt="关闭" title="关闭" />
                    </td>
                </tr>
                <tr>
                    <td colspan="2" style="height: 5px;">
                    </td>
                </tr>
                <tr>
                    <td align="right">
                         用户名:
                    </td>
                    <td>
                         <asp:TextBox ID="txtUserName" runat="server"></asp:TextBox>
                    </td>
                </tr>
                <tr>
                    <td align="right">
                         密   码:
                    </td>
                    <td>
                         <asp:TextBox ID="txtPassword" TextMode="Password" runat="server"></asp:TextBox>
                    </td>
                </tr>
                <tr>
                    <td align="right">
                         验证码:
                    </td>
                    <td>
                         <asp:TextBox ID="txtCode" Style="width: 88px;" runat="server"></asp:TextBox>
                        <img src="Code.aspx" id="imgRndCode" style="vertical-align: middle;" οnclick="ChangeCode(this);"
                            alt="验证码" title="看不清,点击图片更换图片" />
                    </td>
                </tr>
                <tr>
                    <td colspan="2" align="center">
                        <a οnclick="CheckLogin()" id="alogin">登 录</a>
                        <img id="loading" src="Images/Loading/loading04.gif" alt="正在登录" title="正在登录..." />
                        <br />
                        <span id="showMes"></span>
                    </td>
                </tr>
            </table>
        </div>
        <!--登录窗口:End-->
        <div class="main">
            <asp:ContentPlaceHolder ID="MainContent" runat="server" />
        </div>
        <div class="clear">
        </div>
    </div>
    <div class="footer">
        <a href="http://www.cnblogs.com/Ferry/">By Ferry</a>
    </div>
    </form>
</body>
</html>

 2)实现遮罩层和弹出登录界面的层的js文件Scripts/common.js的代码,注意,里面硬写了一些母版页Site.master中的元素的ID

class="language-html">Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->$(class="tags" href="/tags/FUNCTION.html" title=function>function () {
    var screenwidth, screenheight, mytop, getPosLeft, getPosTop
    screenwidth = $(window).width();
    screenheight = $(window).height();
    //获取滚动条距顶部的偏移
    mytop = $(document).scrollTop();
    //计算弹出层的left
    getPosLeft = screenwidth / 2 - 200;
    //计算弹出层的top
    getPosTop = screenheight / 2 - 150;
    //css定位弹出层
    $("#divLoginWindow").css({ "left": getPosLeft, "top": getPosTop });
    //当浏览器窗口大小改变时
    $(window).resize(class="tags" href="/tags/FUNCTION.html" title=function>function () {
        screenwidth = $(window).width();
        screenheight = $(window).height();
        mytop = $(document).scrollTop();
        getPosLeft = screenwidth / 2 - 200;
        getPosTop = screenheight / 2 - 150;
        $("#divLoginWindow").css({ "left": getPosLeft, "top": getPosTop + mytop });
    });
    //当拉动滚动条时,弹出层跟着移动
    $(window).scroll(class="tags" href="/tags/FUNCTION.html" title=function>function () {
        screenwidth = $(window).width();
        screenheight = $(window).height();
        mytop = $(document).scrollTop();
        getPosLeft = screenwidth / 2 - 200;
        getPosTop = screenheight / 2 - 150;
        $("#divLoginWindow").css({ "left": getPosLeft, "top": getPosTop + mytop });
    });
    //点击链接弹出登录窗口
    $("#popup").click(class="tags" href="/tags/FUNCTION.html" title=function>function () {
        $("#divLoginWindow").fadeIn("slow"); //toggle("slow"); 
        $("#txtUserName").focus();
        //获取页面文档的高度
        var docheight = $(document).height();
        //追加一个层,使背景变灰
        $("body").append("<div id='greybackground'></div>");
        $("#greybackground").css({ "opacity": "0.5", "height": docheight });
        return false;
    });
    //点击关闭按钮
    $("#closeBtn").click(class="tags" href="/tags/FUNCTION.html" title=function>function () {
        $("#divLoginWindow").fadeOut("slow"); hide();
        //删除变灰的层
        $("#greybackground").remove();
        return false;
    });
});

//更换验证码图片
class="tags" href="/tags/FUNCTION.html" title=function>function ChangeCode(obj) {
    obj.src = "Code.aspx?" + Math.random();
}

     3)点击【登录】实现AJAX登录验证功能的js文件Scripts/login.js的代码

class="language-javascript">Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->var count = 0;
$(document).ready(class="tags" href="/tags/FUNCTION.html" title=function>function () {
    $("#loading").hide()
});

class="tags" href="/tags/FUNCTION.html" title=function>function CheckLogin() {
    $("#alogin").hide();
    $("#loading").show();
    var txtCode = $("#txtCode");
    var txtName = $("#txtUserName");
    var txtPwd = $("#txtPassword");
    $.class="tags" href="/tags/AJAX.html" title=ajax>ajax({
        url: "CheckLogin.aspx?Code=" + txtCode.val() + "&Name=" + txtName.val() + "&Pwd=" + txtPwd.val(),
        type: "post",
        datatype: "text",
        success: class="tags" href="/tags/FUNCTION.html" title=function>function (returnValue) {
            if (returnValue != "false") {
                $("#popup").hide();
                $("#showMes").hide();
                $("#loginSuccess").html(returnValue + ',您好!');
                $("#divLoginWindow").remove();
                $("#greybackground").remove();
                $("#showMes").hide();
            }
            else {
                count = count + 1;
                $("#loading").hide();
                $("#alogin").show();
                $("#showMes").show();
                $("#showMes").html("<font color=red>登录失败,请检查后重试!(" + count + "次)</font>");
            }
        }
    })
}

4)请求的CheckLogin.aspx的后台代码,前台清除剩Page命令一行

class="language-javascript">Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->using System;
using System.Data;

public partial class CheckLogin : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        try
        {
            String strCode = Request.QueryString["Code"];
            String strName = Request.QueryString["Name"];
            String strPassword = Request.QueryString["Pwd"];

            if (strCode != Session["Code"].ToString())
            {
                Response.Write("false");
            }
            else
            {
                DAO.SqlHelper helper = new DAO.SqlHelper();
                DataTable dt = helper.FillDataTable(String.Format("Select UserName,TrueName From Clients Where UserName='{0}' And Password='{1}'",
                    strName,
                    strPassword
                    ));
                if (dt != null && dt.Rows.Count > 0)
                {
                    Session["TrueName"] = dt.Rows[0]["TrueName"].ToString();
                    Response.Write(dt.Rows[0]["TrueName"].ToString());
                }
                else
                {
                    Response.Write("false");
                }
            }
        }
        catch
        {
            Response.Write("false");
        }
    }
}



http://www.niftyadmin.cn/n/1732312.html

相关文章

开源了一个 JavaScript 版敏感词过滤库

最近在做一个项目&#xff0c;寻遍了 Node 开源社区居然没有发现一个好用的敏感词过滤库&#xff0c;有那么几个库外观上看起来似乎还不错&#xff0c;用起来却一塌糊涂&#xff0c;震惊有余&#xff0c;失望至极。于是花了一天时间自己撸了一个库&#xff0c;库名叫 fastscan&…

Egret白鹭H5开发-围住神经猫

前言 今年9月份跳槽从Android转向前端H5网页和H5小游戏开发&#xff0c;一开始自己学习用Canvas做了拼图、贪吃蛇大作战等小游戏&#xff0c;在公司边学习边用phaser写了个手势识别的小游戏&#xff0c;现在公司想尝试转型Egret白鹭引擎来开发H5&#xff0c;碰巧最近有个类似围…

jQuery 遮罩层效果

最精简&#xff0c;最强大的 jQuery 遮罩层效果。1. 当浏览器改变大小时&#xff0c;遮罩层的大小会相应地改变。2. 遮罩层上方的对话框可随 scroll 的改变而改变&#xff0c;即对话框居中显示。 HTML Code&#xff1a; <div id"main"> <a href"#&qu…

数据可视化:浅谈热力图如何在前端实现

作者 个推开发工程师甄鑫当我们需要用更直观有效的形式来展现各类大数据信息时&#xff0c;热力图无疑是一种很好的方式。作为一种密度图&#xff0c;热力图一般使用具备显著颜色差异的方式来呈现数据效果&#xff0c;热力图中亮色一般代表事件发生频率较高或事物分布密度较大&…

前端文件下载通识篇

前言 前端如何实现下载文件呢?随着前端技术的发展&#xff0c;越来越多的前端需求中会出现下载文件这样的需求。 看着掘金很多人在近期不断的分享有关的文章&#xff0c;我总结了下自己的经验&#xff0c;根据不同情况&#xff0c;总结了一篇算是前端文件下载的通识篇&#…

实现前端弹簧动效

弹簧动效是IOS系统原生自带的一个效果&#xff0c;如在iPhone上面的照片点开大图的展示效果就是一个弹簧动画&#xff0c;如下图所示&#xff1a;它有一个弹闪的过程&#xff0c;一大一小交替缩放就像一个弹簧在弹动一样&#xff0c;而不是以往那种简单的线性变大。 如果使用CS…

屏蔽IE的快捷键

<script> function KeyDown(){ //屏蔽鼠标右键、Ctrln、shiftF10、F5刷新、退格键 //alert("ASCII代码是&#xff1a;"event.keyCode); if ( (window.event.altKey)&& ( (window.event.keyCode37)|| //屏蔽 Alt 方向键 ← (window.event.keyCode39) )…

停留在网页顶部随着滚动条移动而不动JQUERY代码

要讲解里面的原因&#xff0c;请留言。<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns"http://www.w3.org/1999/xhtml"> <head> …