本章主要讲述网页建设中C#代码与前台js实现交互的几种应用
一,如果通过前台javascript调用后台aspx里面的函数?
实现某个功能不同的思路会用不同的实现方法,本章仅做抛砖引玉用方法一、参考本博客前文“ WebForm实现实时信息提醒功能(Timers与Ajax实现及优劣浅析)”方法二,通过AjaxPro直接调用,里面重点是:
1、在后台Load的时候可以注册你的后台类,例如:AjaxPro.Utility.RegisterTypeForAjax(typeof(MyClass));
2、然后注册你的方法
[AjaxPro.AjaxMethod] public string GetUrl() { .... }3、最后前台直接调用就可以了,例如: var str = MyClass.GetUrl().value;
为了表述方便,现在假设引入一个button。那么可以在后台将需要调用或处理的内容写入button_click中;然后在前台写一个js函数,内容为document.getElementById("btn1").click();此函数目的是实现调用后台写好的函数,激发c那个lick事件;
方法二、前台调用如下js代码,含一个隐藏域,目的是触发既定的函数
<script language="javascript">... function SubmitKeyClick() ...{ if (event.keyCode == 13) ...{ event.cancelBubble = true; event.returnValue = false; document.all.FunName.value="你要调用的函数名"; document.form[0].submit(); } } </script> <input onclick="SubmitKeyClick()" id="aaa" type="button"> <input type="hidden" name="FunName"> 〈!--用来存储你要调用的函数 --〉
然后.cs页面的代码如下
public Page_OnLoad() { if (!Page.IsPost()) { string strFunName=Request.Form["FunName"]!=null?Request.Form["FunName"]:"";//根据传回来的值决定调用哪个函数 switch(strFunName) { case "enter()": enter() ; //调用该函数 break; case "其他": //调用其他函数 break; default: //调用默认函数 break; } } } public void enter() { //…… }
二,前台静态页面获取后台函数的变量
方法一:通过页面上隐藏域访问,比如可以放一个隐藏控件,在后台根据条件给其附值,在前台JS里判断其值并根据其值弹出<input id="xx" type="hidden" runat="server">方法二:如后台定义了public;然后前台js中引用该变量的格式为‘<%=n%>‘或"+<%=n%>+"
方法三:或者你可以在服务器端变量赋值后在页面注册一段脚本,然后前端js会自动获取
"<script language=‘javascript‘>var temp=" + tmp + "</script>"
tmp是后台变量,然后js中可以直接访问temp获得值。
三,c# .cs页面通过javascript得到静态页面的变量
方法一:最简单也是最用用的,通过cookie或session或许值,然后保存在服务器端。方法一:1、前台使用静态文本控件隐藏域,将js变量值写入其中;
2、后台用request["id"]来获取值,列如
protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { unInclude = Request.QueryString["uninclude"]; //... } } private string unInclude { set { ViewState["unInclude"] = value; } get { if (ViewState["unInclude"] == null) return ""; return ViewState["unInclude"].ToString(); } }
四,C# .cs页面调用访问javascript的函数
方法一:最简单也是最方便的,通过page类,直接调用:Page.RegisterStartupScript("ggg","<script>SetVisible(1);</script>");方法二:使用Literal类,然后直接在后台写要调用的js函数名或者函数方法,例如:
private void Button2_Click(object sender, System.EventArgs e) { string str; str="<script language=‘javascript‘>"; str+="selectRange()"; str+="</script>"; //Literal1.Visible=true; Literal1.Text=str; }