JS调用服务器端方法
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()
{
//……比如计算某值
}
方法五 直接用XHtmlRequest, client callback, javascript访问Web Service或WebMethod.
以访问WebMethod为例:
1、ScriptManager的EnablePageMethod必须为true.
HTML code
<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePageMethods="true">
<Scripts>
<asp:ScriptReference Path="~/Scripts/MyScript.js" />
</Scripts>
</asp:ScriptManager>
2、服务器方法必须是static方法
C# code
[System.Web.Services.WebMethod]
public static string[] GetStringArray(string s, int cnt)
{
string[] stringArray = new string[cnt];
Random rnd = new Random();
for (int i = 0; i < cnt; i++)
{
stringArray[i] = string.Format("Random{0}: {1}-{2}",i, s, rnd.Next(cnt));
}
//throw new Exception("亲爱的错误");
System.Threading.Thread.Sleep(3000);
return stringArray;
}
3、可以把script代码放到.js文件里,如Scripts目录下的MyScript.js内。
JScript code
function CallWebMethod(prefix,count)
{
$get('result').innerText = "请稍侯...";
PageMethods.GetStringArray(prefix, count, OnSuccess, OnFailed);
return false;
}
function OnSuccess(stringArray)
{
var s = "";
for(var i = 0; i < stringArray.length; i++)
{
s += stringArray[i] + "\n";
}
$get('result').innerText = s;
}
function OnFailed(error, userContext, methodName)
{
if(error != null)
{
alert("发生了亲爱的错误:" + error.get_message());
}
}
//.aspx
HTML code
<form id="form1" runat="server">
<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePageMethods="true">
<Scripts>
<asp:ScriptReference Path="~/Scripts/MyScript.js" />
</Scripts>
</asp:ScriptManager>
<div>
<asp:Label ID="LabelPrefix" AssociatedControlID="TextBoxPrefix" runat="server" Text="string prefix: "></asp:Label>
<asp:TextBox ID="TextBoxPrefix" runat="server"></asp:TextBox>
<asp:Label ID="LabelCnt" AssociatedControlID="TextBoxCnt" runat="server" Text="count: "></asp:Label>
<asp:TextBox ID="TextBoxCnt" runat="server"></asp:TextBox>
<cc1:FilteredTextBoxExtender
ID="FilteredTextBoxExtenderCnt" runat="server"
TargetControlID="TextBoxCnt"
ValidChars="1234567890"
>
</cc1:FilteredTextBoxExtender>
<input id="Button1" type="button" value="button" TextBoxPrefix.ClientID %>').value,$get('<%= TextBoxCnt.ClientID %>').value)" />
</div>
<div id="result" style="border:solid 1px Maroon; margin: 10px; padding;5px;">
</div>
</form>
转自:http://saint.blog.51cto.com/403308/410000
转载于:https://www.cnblogs.com/scy251147/archive/2010/10/25/1860606.html
JS调用服务器端方法相关推荐
- js 调用服务器端方法总结
javascript函数中执行C#代码中的函数: 方法一:1.首先建立一个按钮,在后台将调用或处理的内容写入button_click中; 2.在前台写一个js函数,内容为documen ...
- 使用 AjaxManager 生成调用服务器端方法的 javascript 函数
通过 AjaxManager, 我们可以方便的生成调用 WebService 或者一般处理程序的 javascript 函数, 这样就可以方便的在客户端调用. 本文更新: 2011-12-12: 去掉 ...
- Unity,WebGL, 页面JS调用Unity方法
与WebPlayer类似,在JS中用SendMessage 比如在Unity场景中有一个GameObject,叫A, A上有C#脚本,里面有个方法 public void F(string str) ...
- java 调用服务器文档,JAVA远程调用服务器端方法
JAVA远程调用服务器端方法 内容精选 换一换 Windows Server 2012 R2操作系统弹性云服务器,本地使用远程桌面连接功能连接云服务器并启用redirected drive功能时,云服 ...
- Node.js 调用 C++ 方法 / C++ Addons 详解
最近开发涉及到了一些Node.js调用C++的地方,于是网上搜了一下,发现网上好多文章都是比较片面的东西,没法直接使用.于是花点时间总结一下. Android开发中Java 调用C++的部分叫JNI, ...
- js调用后台方法与后台调用js方法
JS调用后台方法大全 javascript函数中执行C#代码中的函数: 方法一:1.首先建立一个按钮,在后台将调用或处理的内容写入button_click中; 2.在前台写一个js函数,内容为docu ...
- 页面回传与js调用服务器端事件(转)
第一章. Asp.net中服务端控件事件是如何触发的 Asp.net 中在客户端触发服务器端事件分为两种情况: 一. WebControls中的Button 和HtmlControls中的Type ...
- 手把手教你搭建智能合约测试环境、开发、编译、部署以及如何通过JS调用合约方法
链客,专为开发者而生,有问必答! 此文章来自链客区块链技术问答社区,未经允许拒绝转载. 学习目标 了解智能合约 简单环境搭建 能够利用solidity编写Hello World合约 合约部署 和合约互 ...
- 关于datagrid中控件利用js调用后台方法事件的问题
前台调用后台方法除了用button的click事件,还可以用js调用 一.前台页面如图 需求点击这个按钮触发后台事件,从而能够调用存储过程 <epoint:HyperLinkColumn He ...
最新文章
- 如何有效抵抗电脑辐射
- python学会后月薪-零基础python培训后薪资有多少?
- hdu 4004 二分查找
- 【OS】期末总结复习
- C#文件操作基础之File类和FileInfo类
- oracle数据库中函数和存储过程中的区别
- 武汉大学计算机学院 情感分析,跨语言情感分析方法研究
- mysql 免密码进入_MySQL 5.7 三种免密码登录
- 高级工程师究竟比你“高”在哪?
- 算法竞赛学习资源整理
- Django关联数据库时报错TypeError: __init__() missing 1 required positional argument: 'on_delete'...
- 设计模式(五)学习----装饰模式
- vue dve环境static无法被外部访问_vue中的代理转换机制proxyTable配置项
- 原神3.2私人服务器搭建
- 非监督分类ecognition_ENVI遥感影像土地利用分类说明
- 【Atheros】minstrel速率调整算法源码走读
- 短视频矩阵系统源码。抖音矩阵系统源码。抖音SEO源码。
- 共振峰估计2MATLAB
- C#报错:试图加载格式不正确的程序 0x8007000b
- latch:cache buffers chains等待事件导致的latch争用的原理原因与检查
热门文章
- EfficientDet训练自己的物体检测数据集
- AI实战:基于AdvancedEAST的自然场景图像文本检测算法
- 计算机视觉算法岗面经,2019秋招资料
- 基于深度学习算法的NLP集成工具
- glide源码中包含了那种设计模式_源码中的设计模式-单例模式
- mysql参数优化步骤_MySQL架构优化实战系列4:SQL优化步骤与常用管理命令2(转)
- 动态取值_软件测试|动态测试技术
- 小说中人称转换作用_小说创作的最重要的几个要数!
- Android开机自动启动程序设置
- glPushMatrix()和glPopMatrix()以及glLoadIdentity()的理解