JavaScript控制Session操作方法


Posted in Javascript onJanuary 17, 2013

看到这个题目,或许有人会提出疑问,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的理解,还在一步步的进行,如果有什么错误,还望大家积极评论点评

Javascript 相关文章推荐
Java 正则表达式学习总结和一些小例子
Sep 13 Javascript
JS 实现获取打开一个界面中输入的值
Mar 19 Javascript
JavaScript极简入门教程(二):对象和函数
Oct 25 Javascript
Node.js中使用socket创建私聊和公聊聊天室
Nov 19 Javascript
js性能优化技巧
Nov 29 Javascript
jQuery中hover与mouseover和mouseout的区别分析
Dec 24 Javascript
慕课网题目之js实现抽奖系统功能
Sep 19 Javascript
初探js和简单隐藏效果的实例
Nov 23 Javascript
详解Angular5/Angular6项目如何添加热更新(HMR)功能
Oct 10 Javascript
vue-awesome-swiper 基于vue实现h5滑动翻页效果【推荐】
Nov 08 Javascript
详解js根据百度地图提供经纬度计算两点距离
May 13 Javascript
Vue 2.0 侦听器 watch属性代码详解
Jun 19 Javascript
file模式访问网页时iframe高度自适应解决方案
Jan 16 #Javascript
jquery如何改变html标签的样式(两种实现方法)
Jan 16 #Javascript
jquery选择器的选择使用及性能介绍
Jan 16 #Javascript
jQuery旋转插件—rotate支持(ie/Firefox/SafariOpera/Chrome)
Jan 16 #Javascript
用JS提交参数创建form表单在FireFox中遇到的问题
Jan 16 #Javascript
体验js中splice()的强大(插入、删除或替换数组的元素)
Jan 16 #Javascript
Javascript中产生固定结果的函数优化技巧
Jan 16 #Javascript
You might like
星际RPG字典
2020/03/04 星际争霸
基于php设计模式中单例模式的应用分析
2013/05/15 PHP
PHP中file_get_contents函数抓取https地址出错的解决方法(两种方法)
2015/09/22 PHP
phpStorm+XDebug+chrome 配置详解
2019/04/01 PHP
如何在Laravel5.8中正确地应用Repository设计模式
2019/11/26 PHP
兼容IE、FireFox、Chrome等浏览器的xml处理函数js代码
2011/11/30 Javascript
fmt:formatDate的输出格式详解
2014/01/09 Javascript
jquery 获取 outerHtml 包含当前节点本身的代码
2014/10/30 Javascript
js使用DOM操作实现简单留言板的方法
2015/04/10 Javascript
JS选项卡动态替换banner图片路径的方法
2015/05/11 Javascript
使用JavaScript的AngularJS库编写hello world的方法
2015/06/23 Javascript
详解JavaScript的变量和数据类型
2015/11/27 Javascript
springMVC + easyui + $.ajaxFileUpload实现文件上传注意事项
2017/04/23 Javascript
jquery实现企业定位式导航效果
2018/01/01 jQuery
vue兄弟组件传递数据的实例
2018/09/06 Javascript
vue集成百度UEditor富文本编辑器使用教程
2018/09/21 Javascript
JavaScript简单实现的仿微博留言功能示例
2019/01/17 Javascript
jQuery实现每日秒杀商品倒计时功能
2019/09/06 jQuery
解析vue、angular深度作用选择器
2019/09/11 Javascript
[02:14]2016国际邀请赛中国区预选赛Ehome晋级之路
2016/07/01 DOTA
[36:09]Secret vs VG 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.24
2019/09/10 DOTA
在Python程序和Flask框架中使用SQLAlchemy的教程
2016/06/06 Python
Python 3实战爬虫之爬取京东图书的图片详解
2017/10/09 Python
pandas读取CSV文件时查看修改各列的数据类型格式
2019/07/07 Python
python tkinter库实现气泡屏保和锁屏
2019/07/29 Python
Python实现计算长方形面积(带参数函数demo)
2020/01/18 Python
基于梯度爆炸的解决方法:clip gradient
2020/02/04 Python
Django之choices选项和富文本编辑器的使用详解
2020/04/01 Python
基于Keras的格式化输出Loss实现方式
2020/06/17 Python
CSS3实现超慢速移动动画效果非常流畅无卡顿
2014/06/15 HTML / CSS
高中生学习的自我评价
2013/12/14 职场文书
运动会表扬稿大全
2014/01/16 职场文书
企业环保标语
2014/06/10 职场文书
讲文明倡议书
2015/04/29 职场文书
职场新人知识:如何制定一份合理的工作计划?
2019/09/11 职场文书
python实现求纯色彩图像的边框
2021/04/08 Python