第一种把WebService写在页面之外的
看代码吧,我写的有注释大家应该一看就明白了
这是Ajax代码用来调用WebService里
[HTML] 纯文本查看 复制代码 <form id="form1" runat="server">
<input type="button" id="button" value="Random" />
<input type="button" id="button1" value="Random" />
<asp:ScriptManager ID="ScriptManager1" runat="server">
<Services>
<%--在这里引入WebService--%>
<%-- Path是路经, InlineScript ="true"打印出所有的方法,一般为False默认的 --%>
<asp:ServiceReference Path="~/WebService.asmx" />
</Services>
</asp:ScriptManager>
<script language="javascript" type="text/javascript">
//调用WebService里的方法
function GetRandom(minValue,maxValue)
{
//在Script里不能直接,也不可能重载方法,用这种形式来重载是解决这个问题的一种方法,根据参数返回不同的值
if(arguments .length!=2)
{
WebService.getRandom(getrandom);
}else
{
WebService.getRandomisMaxValueorMinValue(minValue ,maxValue,getrandom);
}
}
//回调这个函数用于返回一个值
function getrandom(result)
{
alert (result);
}
</script>
</form>
webService里的代码
[C#] 纯文本查看 复制代码 using System;
using System.Collections;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Xml.Linq;
using System.Web.Script.Services;
/// <summary>
///WebService 的摘要说明
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
//若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消对下行的注释。
[ScriptService]
public class WebService : System.Web.Services.WebService
{
public WebService()
{
//如果使用设计的组件,请取消注释以下行
//InitializeComponent();
}
/// <summary>
/// 产生一个随机数
/// </summary>
/// <returns>INT型</returns>
[WebMethod]
public int getRandom()
{
return new Random(DateTime.Now.Millisecond).Next();
}
/// <summary>
/// 产生一在一定范围内的随机数
/// </summary>
/// <param name="MinValue">参数范围的最小值</param>
/// <param name="MaxValue">参数范围的最大值</param>
/// <returns>INT型</returns>
[WebMethod]
public int getRandomisMaxValueorMinValue(int MinValue, int MaxValue)
{
return new Random(DateTime.Now.Millisecond).Next(MinValue, MaxValue);
}
}
第二种是在界面下面写的
[C#] 纯文本查看 复制代码
看代码吧
WebService代码
[mw_shl_code=csharp,true]//一个服务器端的WerService
[WebMethod]
public static DateTime getDateTime()
{
//显示的是带时区的时间
return DateTime.UtcNow;
}
[/code]
界面里调用的代码
[C#] 纯文本查看 复制代码 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="PageMethods.aspx.cs" Inherits="WebService_PageMethods" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>无标题页</title>
</head>
<body>
<form id="form1" runat="server">
<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePageMethods="true">
</asp:ScriptManager>
<input type="button" value="time" />
<%-- //这样做是不行的,会找不到方法--%>
<%-- <asp:Button ID="Button1" runat="server" Text="Button" OnClick ="Dateime()"/>--%>
<script language="javascript" type="text/javascript">
function Dateime()
{
PageMethods.getDateTime(getDatetime);
}
function getDatetime(result)
{
return alert(result);
}
</script>
</form>
</body>
</html>
|