Javascript 如何在WebForm中从jQueryAjax调用c#方法?
我不熟悉编码,我试图通过jquery ajax调用我的c#方法,因为我的表单操作不允许运行OnClick()事件,我无法删除表单操作,因为我的表单来自专有软件,每次都自动给出表单操作,我试图再次将其更改为默认值,但这不起作用。所以现在我正试图通过jQueryAjax运行我的C#代码。如果你有更好的解决方法,请建议。 谢谢你的帮助,提前谢谢你Javascript 如何在WebForm中从jQueryAjax调用c#方法?,javascript,c#,jquery,asp.net,ajax,Javascript,C#,Jquery,Asp.net,Ajax,我不熟悉编码,我试图通过jquery ajax调用我的c#方法,因为我的表单操作不允许运行OnClick()事件,我无法删除表单操作,因为我的表单来自专有软件,每次都自动给出表单操作,我试图再次将其更改为默认值,但这不起作用。所以现在我正试图通过jQueryAjax运行我的C#代码。如果你有更好的解决方法,请建议。 谢谢你的帮助,提前谢谢你 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="HTMLtoPDF.aspx.cs
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="HTMLtoPDF.aspx.cs"
Inherits="HTMLtoPDF.HTMLtoPDF" %>
<!DOCTYPE html>
<!--[if IE 9]><html class="lt-ie10" lang="en" > <![endif]-->
<html class="no-js" lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="IE=9" />
<title>Incomplete Grade Application</title>
</head>
<body>
<form action="xyz.aspx" id="form1" runat="server" method="post" name="form1">
/// Web Form ///
<div class="row">
<div class="col-sm-12">
<label class="control-label" style="margin-top:0px;margin-left:20px">Please use your mouse/finger sign below:</label>
<div id="esignature"></div>
<input type="hidden" id="bitmap" name="bitmap" value="" />
</div>
</div>
<div class="row">
<div class="col-lg-2 col-md-2 col-sm-2 col-xs-2">
<button type="button" class="btn btn-danger btn-xs" id="clear">Clear Signature</button>
</div>
<div class="col-lg-2 col-lg-offset-6 col-md-2 col-md-offset-6 col-sm-2 col-sm-offset-6 col-xs-2 col-xs-offset-6">
<div class="pull-right">
<input type="submit" class="btn btn-danger" id="reject-button" name="button" value="Reject" />
</div>
</div>
<div class="col-lg-2 col-md-2 col-sm-2 col-xs-2">
<input type="button" ID="submit" class="btn btn-success" value="Approve" />
<button id="hiddenButton" runat="server" onserverclick="btnClick_Click" style="display:none;" ></button>
</div>
</div>
<hr style="background-color:#750D17;height:1px" />
<div class="row">
<div class="col-lg-12">
<input type="text1" class="form-control" id="reject-reason" name="reject-reason">
<p class="help-block">Reject Reasons (if rejected)</p>
</div>
</div>
</div>
</div>
<br />
<br />
</form>
<script src="https://code.jquery.com/jquery-2.1.4.min.js" type="text/javascript"></script>
<script src="https://code.jquery.com/jquery-2.1.4.min.js" type="text/javascript"></script>
<script src="https://code.jquery.com/jquery-migrate-1.3.0.js"></script>
<script src="https://workflow.stratford.edu/Content/bootstrap/js/bootstrap.min.js" type="text/javascript"></script>
<!--[if lt IE 9]>
<script src='https://workflow.stratford.edu/Content/jSignature/flashcanvas.js' type='text/javascript'></script>
<![endif]-->
<script src='https://workflow.stratford.edu/Content/jSignature/jSignature.min.js'></script>
<script type="text/javascript">
var isEmpty = function (element) {
if ($("#" + element).val() == "" || $("#" + element).val() == null) {
return true;
} else {
return false;
}
};
var arrayCheck = function (array) {
for (var i = 0; i < array.length; i++) {
if (array[i] == false) {
return false;
}
};
return true;
};
function arrayAssign(array, num) {
for (var i = 0; i < num; i++) {
array[i] = false;
};
return array;
};
function validationCheck(array, number, element) {
if (isEmpty(element)) {
$("#" + element).parent(".form-group").addClass("has-error");
array[number] = false;
} else {
$("#" + element).parent(".form-group").removeClass("has-error");
array[number] = true;
}
};
var pass1 = [];
$(document).ready(function () {
if ($.browser.msie) {
if (parseInt($.browser.version) < "9.0") {
alert("Sorry! This form does not support your current IE version, please use Firefox/Google Chrome to submit.");
}
}
var preSig = $('#stu-sig-bit').val();
$('#stu-sig').attr('src', preSig);
var fakeVari = $("#typea").val();
$("#esignature").jSignature({
"background-color": "transparent",
"decor-color": "transparent",
"color": "#1489FF",
});
$("#clear").click(function () {
$("#esignature").jSignature("reset");
});
$("input[type=text]").attr("readonly", true);
$("textarea1").attr("readonly", true);
//$("input[type=radio]").attr("disabled", "disabled");
$("#reject-reason").attr("readonly", false);
$("#submit").click(function () {
$("#bitmap").val($("#esignature").jSignature("getData"));
arrayAssign(pass1, 2);
pass1[2] = false;
validationCheck(pass1, 0, "remaining_work");
validationCheck(pass1, 1, "deadline_date");
pass1[2] = true;
if (!arrayCheck(pass1)) {
return false;
}
else if ($("#esignature").jSignature("getData", "native").length == 0) {
alert("Please sign at bottom of the form.");
return false;
} else {
$("#iso_sig").val($("#bitmap").val());
$("#iso_decision").val("no");
var date = new Date();
var month = date.getMonth() + 1;
var day = date.getDate();
var temp = (month < 10 ? "0" : "") + month + "/" + (day < 10 ? "0" : "") + day + "/" + date.getFullYear();
$("#iso_date").val(temp);
var answer = confirm('Are you sure you want to approve the case?');
if (answer == true) {
document.getElementById('<%= hiddenButton.ClientID %>').click();
} else {
return false;
}
}
});
$("#reject-button").click(function () {
$("#bitmap").val($("#esignature").jSignature("getData"));
if (isEmpty("reject-reason")) {
alert("Please write down the reason why you reject the request.");
return false;
} else if ($("#esignature").jSignature("getData", "native").length == 0) {
alert("Please sign at bottom of the form.");
return false;
} else {
$("#iso_sig").val($("#bitmap").val());
$("#iso_decision").val("no");
var date = new Date();
var month = date.getMonth() + 1;
var day = date.getDate();
var temp = (month < 10 ? "0" : "") + month + "/" + (day < 10 ? "0" : "") + day + "/" + date.getFullYear();
$("#iso_date").val(temp);
var answer = confirm('Are you sure you want to reject the case?');
if (answer == true) {
} else {
return false;
}
}
});
});
</script>
}您可以实现web服务,或者使用处理程序文件。通常使用这个通用处理程序,因为它不需要表单。使用模板后,您将拥有一个文件,该文件应显示如下:
public class SampleHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
}
public bool IsReusable
{
get { return false; }
}
}
<script type="text/javascript">
$.ajax({
url: '<% Page.ResolveUrl("/SampleHandler.ashx") %>',
method: 'post',
...,
success : function (response) {
// Handle .ashx response.
}
});
</script>
从主应用程序或表单中,您可以按如下方式执行ajax:
public class SampleHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
}
public bool IsReusable
{
get { return false; }
}
}
<script type="text/javascript">
$.ajax({
url: '<% Page.ResolveUrl("/SampleHandler.ashx") %>',
method: 'post',
...,
success : function (response) {
// Handle .ashx response.
}
});
</script>
$.ajax({
url:“”,
方法:“post”,
...,
成功:功能(响应){
//Handle.ashx响应。
}
});
这是最简单的方法之一。与在
[WebMethod]
属性中修饰的代码中声明方法相比,它允许您分离逻辑。您可以实现一个web服务,或者使用一个处理程序文件。通常使用这个通用处理程序,因为它不需要表单。使用模板后,您将拥有一个文件,该文件应显示如下:
public class SampleHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
}
public bool IsReusable
{
get { return false; }
}
}
<script type="text/javascript">
$.ajax({
url: '<% Page.ResolveUrl("/SampleHandler.ashx") %>',
method: 'post',
...,
success : function (response) {
// Handle .ashx response.
}
});
</script>
从主应用程序或表单中,您可以按如下方式执行ajax:
public class SampleHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
}
public bool IsReusable
{
get { return false; }
}
}
<script type="text/javascript">
$.ajax({
url: '<% Page.ResolveUrl("/SampleHandler.ashx") %>',
method: 'post',
...,
success : function (response) {
// Handle .ashx response.
}
});
</script>
$.ajax({
url:“”,
方法:“post”,
...,
成功:功能(响应){
//Handle.ashx响应。
}
});
这是最简单的方法之一。因为它将允许您分离逻辑,与在
[WebMethod]
属性中修饰的代码中声明方法相比。我按照您所说的创建了处理程序,但我不知道应该将我的c代码放在哪里?@Naive您的c代码将放在流程请求中,您可以通过当前的HttpContext
返回它,您可以通过HttpContext
访问特定数据。我可以用jquery ajax直接调用C#code吗?$。ajax({url:'',方法:'post',success:function(response){alert(“success”);})@好吧,您可以点击该.aspx页面,然后让页面加载通过HttpContext.Response.End()返回内容但是这确实不是正确的方法。你真的应该向外抽象,并使用一个服务来自动为你处理该功能。谢谢你,现在我正试图通过handler实现,正如你所说,它会让你知道输出是什么,但我真的很感谢你的帮助。我按照你说的创建了handler,但是我不知道我应该把我的c#代码放在哪里?@Naive你的c#代码会进入进程请求,你会通过当前的HttpContext
返回它,你可以通过HttpContext
访问特定的数据。我可以直接用jquery ajax调用c#代码吗?$。ajax({url:'',方法:'post',success:function(response){alert(“success”);})@好吧,您可以点击该.aspx页面,然后让页面加载通过HttpContext.Response.End()返回内容但是这确实不是正确的方法。你真的应该向外抽象,并使用一个服务为你自动处理该功能。谢谢你,现在我正试图通过handler实现,正如你所说,它会让你知道输出是什么,但我真的很感谢你的帮助。refere@Dhaval会行得通吗,因为C#file中的方法是无效的,需要静态,因为我尝试了该链接中给出的示例,但它只给出了成功的警告消息,而没有调用该方法。reference@Dhaval会起作用吗,因为C#file中的方法是无效的,需要静态的,因为我尝试了该链接中给出的示例,但它只给出了成功的警告消息,而没有调用该方法。