您好,欢迎访问一九零五行业门户网

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

本篇文章给大家介绍一下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的理解,还在一步步的进行,如果有什么错误,还望大家积极评论点评
更多编程相关知识,请访问:编程入门!!
其它类似信息

推荐信息