直接在AspX前台頁面HTML代碼中要放的位置寫入如下代碼:
(2)用JS取本頁面中的服務器端控件值:
服務器端控件值:
{
vari;
i=document.getElementById('<%=服務器控件id.ClientID %>').value;
//取Label控件值
document.getElementById('<%=lblUserName.ClientID %>').innerText=i;
}
(3)用JS取自定義用戶控件(**.ascx)中的
{
//.ascx用戶控件在本頁面上的id,即<uc>標簽中的ID名稱,再加上.ascx頁面里面的服務器控件ID
//並用"_"連 接
var j=document.getElementById('<%=UC的ID.ClientID %>'+"_txtID").value;//TextBox
//在取Label控件的值時改用下面的寫法,可能有些朋友也用了上面的寫法,所以取不到吧……
var jj=document.getElementById('<%=UC的ID.ClientID %>'+"_txtID")..innerHTML;//Label
}
補充一下:
對於服務器端控件里調用js,不可以直接綁后台變量,要先聲明一下js變量,賦值為后台變量
<script>
var testTxt=" <%=stetValue %>";
</script>
<div>
<input type="button" onclick="return confirm('<%=stetValue %>')" value="測試" /> //客戶端控件可以直接用
<asp:Button ID="Button1" runat="server" Text="測試" OnClientClick="return confirm(testTxt)" />
</div>
此外:
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;
}