最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
當前位置: 首頁 - 科技 - 知識百科 - 正文

JavaScript如何控制Session實現(xiàn)原理及代碼

來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 22:52:24
文檔

JavaScript如何控制Session實現(xiàn)原理及代碼

JavaScript如何控制Session實現(xiàn)原理及代碼:看到這個題目,或許有人會提出疑問,JavaScript代表客戶端,而Session代表的是服務器(不知道這樣說大家是否能夠理解)。 先說一下需求,我在做一個權限管理的時候,需要在點擊某個模塊時,Session中相應的改變模塊代號,而實現(xiàn)這個操作的是一個a標簽,當然
推薦度:
導讀JavaScript如何控制Session實現(xiàn)原理及代碼:看到這個題目,或許有人會提出疑問,JavaScript代表客戶端,而Session代表的是服務器(不知道這樣說大家是否能夠理解)。 先說一下需求,我在做一個權限管理的時候,需要在點擊某個模塊時,Session中相應的改變模塊代號,而實現(xiàn)這個操作的是一個a標簽,當然

看到這個題目,或許有人會提出疑問,JavaScript代表客戶端,而Session代表的是服務器(不知道這樣說大家是否能夠理解)。

先說一下需求,我在做一個權限管理的時候,需要在點擊某個模塊時,Session中相應的改變模塊代號,而實現(xiàn)這個操作的是一個a標簽,當然我不知道 一個linkbutton是否可以同時將跳轉頁面和修改Session做了,個人感覺應該是可以的,具體能不能,如果有人做了Demo可以留言說明。

a標簽,實現(xiàn)頁面的跳轉,他的onclick事件,執(zhí)行的也是本頁面中的js方法,現(xiàn)在就回到了題目所描述的問題——寫一個JavaScript方法,使其修改Session。

其實這個例子不難,但是對我個人的意義卻非同尋常,這個例子解除了我一大部分對AJAX的恐懼。

首先,是寫一個一般處理程序(也就是服務端代碼)

需要說明的是,如果要修改Session,需要額外引入命名空間,和實現(xiàn)一個接口(只需實現(xiàn),別的什么也不用做)
代碼如下:

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;
}
}
}
}

有沒有發(fā)現(xiàn)上面實現(xiàn)的功能很簡單呢?

下面,是客戶端代碼

代碼如下:

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("當前瀏覽器不支持創(chuàng)建XMLHTTPREQUEST對象,請更換瀏覽器");
return;
}

xmlhttp.onreadystatechange = callback;

xmlhttp.open("GET", "ModifySession.ashx?session=" + session, true);
xmlhttp.send(null);
}

function callback() {
//判斷和服務器的交互是否完成,還要判斷服務器端是否返回了數(shù)據(jù)
if (xmlhttp.readyState == 4) {
//表示和服務器端的交互完成
if (xmlhttp.status == 200) {
//alert("正確返回了數(shù)據(jù)");
return;
}
}
}

在回調函數(shù)中,我只寫了一個測試正常返回數(shù)據(jù)的語句,后來注釋掉了。

在為a標簽綁定事件時,我最初用的是拼接字符串的方法,就是從數(shù)據(jù)庫中查到模塊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>

是不是這樣寫,感覺會清晰好多呢,因為我之前用的拼接字符串,并且實現(xiàn)了,用Repeater只是一個思路,在id拼接那不知道會不會又問題,如果有問題,歡迎斧正。

至此,我的第一篇有關AJAX的文章就寫完了,關于對AJAX的理解只是一個開始,這個里面沒有涉及到數(shù)據(jù)交互,所以對于某些知識的解釋還是有些蒼白的,隨著學習的深入,關于AJAX的使用,不會僅僅停留在updatepanel和timer這些控件上的。對于某些不太難的實例,自己做一下還是比較好的。

關于這個例子,你可以問用一個LinkButton其實就可以實現(xiàn),干嘛弄這么麻煩,但是我想說,我一開始也沒有想到一個LinkButton就可以解決,是自己把問題復雜化了,這個里面涉及到一個頁面跳轉,其實完全可以用LinkButton解決,但是學習嘛就是一個過程,用自己犯的一個小迷糊促進了對AJAX的理解,何嘗不是一件快事~~

對于AJAX的理解,還在一步步的進行,如果有什么錯誤,還望大家積極評論點評

聲明:本網(wǎng)頁內容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JavaScript如何控制Session實現(xiàn)原理及代碼

JavaScript如何控制Session實現(xiàn)原理及代碼:看到這個題目,或許有人會提出疑問,JavaScript代表客戶端,而Session代表的是服務器(不知道這樣說大家是否能夠理解)。 先說一下需求,我在做一個權限管理的時候,需要在點擊某個模塊時,Session中相應的改變模塊代號,而實現(xiàn)這個操作的是一個a標簽,當然
推薦度:
標簽: 原理 管理 js
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top