net中前台javascript與後台c#函數如何相互連信

來源:互聯網
上載者:User

C#代碼與javaScript函數的相互調用

問:
1.如何在JavaScript訪問C#函數?
2.如何在JavaScript訪問C#變數?
3.如何在C#中訪問JavaScript的已有變數?
4.如何在C#中訪問JavaScript函數?

問題1答案如下:
javaScript函數中執行C#代碼中的函數:
方法一:1、首先建立一個按鈕,在後台將調用或處理的內容寫入button_click中;
          2、在前台寫一個js函數,內容為document.getElementById("btn1").click();
          3、在前台或後台調用js函數,激發click事件,等於訪問後台c#函數;

方法二:1、函式宣告為public              
             後台代碼(把public改成protected也可以)
             public string ss()
             {
                return("a");
             }
          2、在html裡用<%=fucntion()%>可以調用
             前台指令碼
             <script language=javascript>
             var a = "<%=ss()%>";
             alert(a);
             </script>
方法三:1、<script language="javascript">
             <!--
             function __doPostBack(eventTarget, eventArgument)
             {
                var theForm = document.Form1;       //指runat=server的form
                theForm.__EVENTTARGET.value = eventTarget;
                theFrom.__EVENTARGUMENT.value = eventArgument;
                theForm.submit();
             }
             -->
             </script>
             <input id="Button1" type="button" name="Button1" value="按鈕" onclick="javascript:__doPostBack('Button1','')">
         
方法四:<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 onkeypress="SubmitKeyClick()" id="aaa" type="text">
<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()
{
//……比如計算某值
}

問題2.如何在JavaScript訪問C#變數?
答案如下:
方法一:1、通過頁面上隱藏欄位訪問<input id="xx" type="hidden" runat="server">
方法二:1、如後台定義了PUBLIC STRING N;前台js中引用該變數的格式為'<%=n%>'或"+<%=n%>+"
方法三:1、或者你可以在伺服器端變數賦值後在頁面註冊一段指令碼
             "<script language='javascript'>var temp=" + tmp + "</script>"
             tmp是後台變數,然後js中可以直接存取temp獲得值。

3.如何在C#中訪問JavaScript的已有變數?

答案如下:

方法一:1、前台使用靜態文本控制項隱藏欄位,將js變數值寫入其中;
          2、後台用request["id"]來擷取值;

方法二:可以用cookie或session

4.如何在C#中訪問JavaScript函數?
答案如下:
c#代碼中執行javaScript函數:
方法一:1、Page.RegisterStartupScript("ggg","<script>SetVisible(1);</script>");
方法二:使用Literal類,然後
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;
}

備忘:

1、使用Page.ClientScript.RegisterClientScriptBlock

RegisterClientScriptBlock方法可以把JavaScript函數放在頁面的頂部。也就是說,該指令碼用於在瀏覽器中啟動頁面。

Code

<%@ Page Language="C#" %>

<script runat="server">

protected void Page_Load(object sender,EventArgs e)

{

string myScript = @"function AlertHello() { alert('Hello ASP.NET'); }";

Page.ClientScript.RegisterClientScriptBlock(this.GetType(),

"MyScript",myScript,true);

}

</script>

在這個例子中,把JavaScript函數AlertHello()建立為一個字串myScript。然後使用Page. ClientScript.RegisterClientScriptBlock方法編寫放在頁面上的指令碼。RegisterClientScriptBlock方法的兩個構建方式如下:

● RegisterClientScriptBlock (type,key,script)

● RegisterClientScriptBlock (type,key,script,script tag specification)

例: Page.ClientScript.RegisterStartupScript(this.GetType(),"hehe", "<script>selectRange();</script>");
        Page.RegisterStartupScript("hehe", "<script>selectRange();</script>");

4.4.2 使用Page.ClientScript.RegisterStartupScript

RegisterStartupScript方法與RegisterClientScriptBlock方法的區別不大。最大的區別是RegisterStartupScript把指令碼放在ASP.NET頁面的底部,而不是頂部。實際上,RegisterStartup Script方法甚至使用與RegisterClientScriptBlock方法相同的建構函式:

● RegisterStartupScript (type,key,script)

● RegisterStartupScript (type,key,script,script tag specification)

那麼,在頁面上註冊指令碼的過程有什麼區別?實際上區別很大!

如果在頁面上有一些處理控制項的JavaScript,在大多數情況下應使用RegisterStartupScript方法,而不是RegisterClientScriptBlock方法。

就是,尋找、調用頁面控制項的時候,就使用 Page.ClientScript.RegisterStartupScript

4.4.3使用Page.ClientScript.RegisterClientScriptInclude

最後一個方法是RegisterClientScriptInclude。許多開發人員都把JavaScript放在.js檔案中,這是最好的方式,因為很容易把對JavaScript的修改應用於整個應用程式。使用RegisterClientScriptInclude方法可以在ASP.NET頁面上註冊指令檔,如下所示。

string myScript = "myJavaScriptCode.js"

Page.ClientScript.RegisterClientScriptInclude("myKey",myScript);

 

文法C#

public void RegisterClientScriptBlock ( Type type, string key, string script, bool addScriptTags)

參數

type 要註冊的用戶端指令碼的類型。
key 要註冊的用戶端指令碼的鍵。
script 要註冊的用戶端指令碼文本。
addScriptTags 指示是否添加指令碼標記的布爾值。

public void RegisterStartupScript ( Type type, string key, string script, bool addScriptTags)

參數

type 要註冊的啟動指令碼的類型。
key 要註冊的啟動指令碼的鍵。
script 要註冊的啟動指令碼文本。
addScriptTags 指示是否添加指令碼標記的布爾值

public void RegisterStartupScript ( Type type, string key, string script)

參數

type 要註冊的啟動指令碼的類型。
key 要註冊的啟動指令碼的鍵。
script 要註冊的啟動指令碼文本。

本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/zjj780320380/archive/2010/04/17/5495948.aspx

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.