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=#>}

可是这样写的很容易出错,虽然在复制进来之前,我是写过测试语句,然后再将变量写到该写位置的,但是这样写出来的语句是很难进行调试的。
在和别人交流的过程中,说道了Repeater控件,恍然大悟,我重复的这个过程,不就是Repeater控件干的事么?控件替我们干了,干嘛还要自己写这么容易出错的代码呢?
复制代码 代码如下:

<asp:Repeater runat="server" id="rptModel">
<ItemTemplate>
<li><a id='model'+'<%#Eval("mdlID")%>' href=#></ItemTemplate>
</asp:Repeater>

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

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

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

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

本页内容版权归属为原作者,如有侵犯您的权益,请通知我们删除。
复制代码 代码如下: !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 meta http-equiv="Content-Type" content="text/html; charset=UTF-8" / titleJS 关
前期的准备工作: 1、下载DEMO源码,并升级为最新版本(jquery 1.7.2,Easyui 1.2.6),直接替换就可以啦,升级easyui 是的要把css js theme 全部替换 2、在首页的HTML代码中:将 复制代码 代码如下: div id="mm" class="easyui-menu" div id="mm-tabupdate"刷新/div div class="menu-sep"/div div id="mm-tabclose"关闭/div div id="mm-tabcloseal
要更新的页面 复制代码 代码如下: !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 title/title script src="js/jquery.js" type="text/javascript"/script /h
调用对象位于作用域链的前端,局部变量(在函数内部用var声明的变量)、函数参数及Arguments对象都在函数内的作用域中——这意味着它们隐藏了作用域链更上层的任何同名的属性。 2010年9月14日,我去参加网易网页工程师招聘会,应聘JS工程师职位。有幸参加笔试,然后有幸栽在笔试,呵呵。废话少说,抓出音响极深的一题重新研究研究。 题目大概是:写出如下代码的输出结果并进行分析 复制代码 代码如下: var tt = 'aa'; function test(){ alert(tt); var tt = 'dd'
【问题原因】 这个应该是 jquery.datatable 控件本身的一个缺陷。 该控件中的checkbox小插件的id是写死的,所以当有多个datatable引用到一个页面中的时候,全选事件会匹配全部的datatable,所以造成全部多个表格的checkbox被都被选中。 【解决方法】 所以最好是修改jquery.datatable控件,给生成的每个datatable下的checkbox赋 予不同的id,因为datatable的id是不一样的,所以可以把 datatable的id作为 checkbox的前
PHP的数组函数in_array()非常方便,可JS就不是了。其实我很不喜欢JS的数组~ 别说了,直接上方法 复制代码 代码如下: Array.prototype.in_array = function(e) { for(i=0;ithis.length;i++) { if(this[i] == e) return true; } return false; } 或者 复制代码 代码如下: Array.prototype.in_array = function(e) { for(i=0;ithis.leng
css 复制代码 代码如下: style .xMarquee{border:1px solid #ccc;height:25px;width:500px; margin:50px auto; background:#ffffff; overflow:hidden;} .xMarquee ol{list-style-type:none; margin:0px; padding:0px; font-size:12px; width:100000%;} .xMarquee ol li{float:left;}
在 Node.js 中,我使用 node-schedule 来执行定时任务。Cron-style 的时间格式对于初学者不太直观,所以一般使用这种方式:比如官方示例中的每个小时的 42 分执行任务 复制代码 代码如下: var schedule = require('node-schedule'); var rule = new schedule.RecurrenceRule(); rule.minute = 42; var j = schedule.scheduleJob(rule, function()
关于js获取flash对象,网上有非常多的例子,我也尝试了不少方法。 虽然都能用,但是没有我最想要的东西, 后来看了下百度的,虽然很规范,各种情况都考虑到了,但是代码量却不是不容乐观, 前前后后将近20行代码,压缩后也有 864 个字节。 所以本文诞生了。 我想测试并分享下网上收集的几种我比较满意的方法。 也顺便请大家帮忙测试下兼容性,有不兼容的在下面留个言,最好写上浏览器版本,这样我也好测试并修复代码。 下面来看代码吧。 复制代码 代码如下: function getFlashMovieObject( m
swfupload上传编辑器是一款支持本地上传、预览、视频拍照和网络加载的flash头像编辑上传插件,可缩放、裁剪、旋转、定位和调色等,同时支持asp、asp.net、jsp、php等多语种 复制代码 代码如下: swfobject.addDomLoadEvent(function () { var swf = new fullAvatarEditor("swfContainer", { id: 'swf', upload_url: 'asp/Upload.asp', src_upload:2 }, fu