• 技术文章 >web前端 >js教程

    JavaScript如何控制Session操作?方法介绍

    PHPzhongPHPzhong2021-05-31 10:35:37转载741
    本篇文章给大家介绍一下JavaScript控制Session操作的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

    看到这个题目,或许有人会提出疑问,JavaScript代表客户端,而Session代表的是服务器(不知道这样说大家是否能够理解)。

    先说一下需求,我在做一个权限管理的时候,需要在点击某个模块时,Session中相应的改变模块代号,而实现这个操作的是一个a标签,当然我不知道 一个linkbutton是否可以同时将跳转页面和修改Session做了,个人感觉应该是可以的,具体能不能,如果有人做了Demo可以留言说明。

    a标签,实现页面的跳转,他的onclick事件,执行的也是本页面中的js方法,现在就回到了题目所描述的问题——写一个JavaScript方法,使其修改Session。

    其实这个例子不难,但是对我个人的意义却非同寻常,这个例子解除了我一大部分对AJAX的恐惧。
    首先,是写一个一般处理程序(也就是服务端代码)

    需要说明的是,如果要修改Session,需要额外引入命名空间,和实现一个接口(只需实现,别的什么也不用做)

    代码如下:

    using System; 
    using System.Collections.Generic; 
    using System.Linq; 
    using System.Web; 
    using System.Web.SessionState; 
    namespace TGB.CJX 
    { 
    /// <summary> 
    /// 修改Session 
    /// </summary> 
    public class ModifySession : IHttpHandler,IRequiresSessionState 
    { 
    public void ProcessRequest(HttpContext context) 
    { 
    context.Response.ContentType = "text/plain"; 
    context.Session["modelID"]=context.Request.QueryString["session"].ToString(); 
    //context.Session["modelID"] = "1"; 
    //context.Response.Write(context.Session["modelID"]); 
    } 
    public bool IsReusable 
    { 
    get 
    { 
    return false; 
    } 
    } 
    } 
    }

    有没有发现上面实现的功能很简单呢?

    下面,是客户端代码

    代码如下:

    var xmlhttp; 
    var session; 
    function submit(obj) { 
    //session = obj.id.substr(1, 1); 
    session = obj.id.replace("model",""); 
    //IE7,IE8,FF,MOZILLA,SAFARI 
    if (window.XMLHttpRequest) { 
    //alert("IE7,IE8,FF,MOZILLA,SAFARI"); 
    xmlhttp = new XMLHttpRequest(); 
    if (xmlhttp.overrideMinmeType) { 
    xmlhttp.overrideMinmeType("text/xml"); 
    } 
    } else if (window.ActiveXObject) { 
    //alert("IE5,IE6"); 
    var activeName = ["MSXML2.XMLHTTP", "Miscrosoft.XMLHTTP"]; 
    for (var i = 0; i < activeName.length; i++) { 
    try { 
    xmlhttp = new ActiveXObject(activeName[i]); 
    break; 
    } catch (e) { 
    return; 
    } 
    } 
    } 
    if (xmlhttp == undefined || xmlhttp == null) { 
    alert("当前浏览器不支持创建XMLHTTPREQUEST对象,请更换浏览器"); 
    return; 
    } 
    xmlhttp.onreadystatechange = callback; 
    xmlhttp.open("GET", "ModifySession.ashx?session=" + session, true); 
    xmlhttp.send(null); 
    } 
    function callback() { 
    //判断和服务器的交互是否完成,还要判断服务器端是否返回了数据 
    if (xmlhttp.readyState == 4) { 
    //表示和服务器端的交互完成 
    if (xmlhttp.status == 200) { 
    //alert("正确返回了数据"); 
    return; 
    } 
    } 
    }

    在回调函数中,我只写了一个测试正常返回数据的语句,后来注释掉了。
    在为a标签绑定事件时,我最初用的是拼接字符串的方法,就是从数据库中查到模块ID和模块名称,然后通过下面的一条语句进行语句拼接:

    StringBuilder sbModel = new StringBuilder(); 
    //将可以访问的模块进行菜单拼接 
    for (int i = 0; i < dtModel.Rows.Count; i++) 
    { 
    sbModel.Append("<li><a id='model" + dtModel.Rows[0]["mdlID"].ToString() + "' href='SpaceWeb.aspx' target='_parent' runat='server' onclick='submit(this)'>" + dtModel.Rows[i]["mdlName"].ToString() + "</a></li>"); 
    }

    可是这样写的很容易出错,虽然在复制进来之前,我是写过测试语句,然后再将变量写到该写位置的,但是这样写出来的语句是很难进行调试的。

    在和别人交流的过程中,说道了Repeater控件,恍然大悟,我重复的这个过程,不就是Repeater控件干的事么?控件替我们干了,干嘛还要自己写这么容易出错的代码呢?

    <asp:Repeater runat="server" id="rptModel"> 
    <ItemTemplate> 
    <li><a id='model'+'<%#Eval("mdlID")%>' href="SpaceWeb.aspx" target="_parent" runat="server" onclick="submit(this)"><%#Eval("mdlName" %></a></li> 
    </ItemTemplate> 
    </asp:Repeater>

    是不是这样写,感觉会清晰好多呢,因为我之前用的拼接字符串,并且实现了,用Repeater只是一个思路,在id拼接那不知道会不会又问题,如果有问题,欢迎斧正。

    至此,我的第一篇有关AJAX的文章就写完了,关于对AJAX的理解只是一个开始,这个里面没有涉及到数据交互,所以对于某些知识的解释还是有些苍白的,随着学习的深入,关于AJAX的使用,不会仅仅停留在updatepanel和timer这些控件上的。对于某些不太难的实例,自己做一下还是比较好的。

    关于这个例子,你可以问用一个LinkButton其实就可以实现,干嘛弄这么麻烦,但是我想说,我一开始也没有想到一个LinkButton就可以解决,是自己把问题复杂化了,这个里面涉及到一个页面跳转,其实完全可以用LinkButton解决,但是学习嘛就是一个过程,用自己犯的一个小迷糊促进了对AJAX的理解,何尝不是一件快事~~

    对于AJAX的理解,还在一步步的进行,如果有什么错误,还望大家积极评论点评

    更多编程相关知识,请访问:编程入门!!

    声明:本文转载于:脚本之家,如有侵犯,请联系admin@php.cn删除
    上一篇:SOSO地图API使用(一)在地图上画圆实现思路与代码_javascript技巧 下一篇:js 实现在离开页面时提醒未保存的信息(减少用户重复操作)_javascript技巧
    大前端线上培训班

    相关文章推荐

    • 学会这20+个JavaScript单行代码,让你像专业人士一样编写代码• JavaScript中解析parseInt()的怪异行为• JavaScript的整除符号是什么• javascript如何检测网络• javascript怎么删除html• 聊聊JavaScript中eval()函数的用法

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网