[英]How to pass a json variable from a CS file to an Javascript function?
我在C#中有一个方法,该方法创建用户凭证的JSON对象。 以下是CS文件。
public string CreateLoginjson(string strErrorType, bool blIsAuthenticated)
{
StringBuilder sbLoginJson = new StringBuilder();
if (blIsAuthenticated)
{
sbLoginJson.Append("{LoginSuccess:1");
}
else
{
sbLoginJson.Append("{LoginSuccess:0");
}
if (strErrorType != string.Empty)
{
if (strErrorType.TrimEnd(new char[] { ',' }) == "Token" ||
strErrorType.TrimEnd(new char[] { ',' }) == "BlankToken")
{
sbLoginJson.Append(",txtTestTokenNumber1:\"Error\"");
sbLoginJson.Append(",txtTestTokenNumber2:\"Error\"");
sbLoginJson.Append(",txtTestTokenNumber3:\"Error\"");
sbLoginJson.Append(",txtTestTokenNumber4:\"Error\"");
}
if (strErrorType.TrimEnd(new char[] { ',' }) == "Password")
{
sbLoginJson.Append(",txtPassword:\"Error\"");
}
if (strErrorType.TrimEnd(new char[] { ',' }) == "UserName")
{
sbLoginJson.Append(",UserName:\"Error\"");
}
string strLoadErrorControlMessage = LoadErrorControl(strErrorType,
string.Empty);
if (strLoadErrorControlMessage!= string.Empty)
{
sbLoginJson.Append(",ErrorMessage:
'" + strLoadErrorControlMessage + "'");
}
}
sbLoginJson.Append("}");
var LoginJson = sbLoginJson.ToString();
return LoginJson;
}
现在,我需要将LoginJson传递给JS函数,该函数检查是否提供了不正确的凭据,该函数查找控件并向其中添加属性
function GetLoginJson(strLoginJson) {
if (strLoginJson != '' && strLoginJson != undefined) {
var objLoginJson = strLoginJson;
if (objLoginJson.LoginSuccess == "1") {
}
else if (objLoginJson.LoginSuccess == "0") {
if (objLoginJson.txtUserName != ''
&& objLoginJson.txtUserName != undefined)
{
$('#txtUserName').attr("class", objLoginJson.txtUserName);
}
else
{
$('#txtUserName').attr("class", "Input");
}
if (objLoginJson.txtPassword != ''
&& objLoginJson.txtPassword != undefined)
{
$('#txtPassword').attr("class", objLoginJson.txtPassword);
}
else
{
$('#txtPassword').attr("class", "Input");
}
if (objLoginJson.txtTestTokenNumber1 != ''
&& objLoginJson.txtTestTokenNumber1 != undefined)
{
$('#txtTestTokenNumber1').attr("class",
objLoginJson.txtTestTokenNumber1);
}
else
{
$('#txtTestTokenNumber1').attr("class", "Error");
}
if (objLoginJson.txtTestTokenNumber2 != ''
&& objLoginJson.txtTestTokenNumber2 != undefined)
{
$('#txtTestTokenNumber2').attr("class",
objLoginJson.txtTestTokenNumber2);
}
else
{
$('#txtTestTokenNumber2').attr("class", "Error");
}
if (objLoginJson.txtTestTokenNumber3 != '' &&
objLoginJson.txtTestTokenNumber3 != undefined) {
$('#txtTestTokenNumber3').attr("class",
objLoginJson.txtTestTokenNumber3);
}
else
{
$('#txtTestTokenNumber3').attr("class", "Error");
}
if (objLoginJson.txtTestTokenNumber4 != '' &&
objLoginJson.txtTestTokenNumber4 != undefined) {
$('#txtTestTokenNumber4').attr("class",
objLoginJson.txtTestTokenNumber4);
}
else
{
$('#txtTestTokenNumber4').attr("class", "Error");
}
$('#ErrorControl').html('');
}
}
}
我想将CS中的JSON变量传递给此jQuery语句$('#ErrorControl')。html('');'
谢谢
如果用户提供所有信息并单击某些东西(任何控件),则可以从jquery发出ajax请求。 如果要从CS返回一些错误消息,则可以将该消息直接用作
$('#ErrorControl')。html(response.d)
d =“您要从CS重播的字符串”。
其中,响应是成功功能的参数。 d是接收对象的默认属性(变量)。
如果您不想直接显示字符串,请使用返回的数据并调用另一个javascript函数。
谢谢
用户1502890,
我不太了解C#,但您似乎正在尝试直接构建JSON字符串。 构造一个对象,然后使用内置语言命令或实用程序方法将其字符串化为JSON,这是更正常(更简便,更可靠)的方法。 我想这在C#中一定是可能的。
假设凭据字段采用id="credentialsForm"
的形式,并且服务器端脚本可作为相对URL“ myCredentialsChecker.xtn”请求,则jQuery将如下所示:
$(function() {
function loginResponse(j) {
j = j || {};
if (j.LoginSuccess) {
//...
}
else {
$('#txtUserName').attr("class", j.txtUserName ? j.txtUserName : "Input");
$('#txtPassword').attr("class", j.txtPassword ? j.txtPassword : "Input");
$('#txtTestTokenNumber1').attr("class", j.txtTestTokenNumber1 ? j.txtTestTokenNumber1 : "Error");
$('#txtTestTokenNumber2').attr("class", j.txtTestTokenNumber2 ? j.txtTestTokenNumber2 : "Error");
$('#txtTestTokenNumber3').attr("class", j.txtTestTokenNumber3 ? j.txtTestTokenNumber3 : "Error");
$('#txtTestTokenNumber4').attr("class", j.txtTestTokenNumber4 ? j.txtTestTokenNumber4 : "Error");
$('#ErrorControl').html('');
}
}
$("#credentialsForm").on('submit', function() {
$.ajax({
url: "myCredentialsChecker.xxx",
data: $(this).serialize(),
type: 'POST', // or 'GET'
dataType: 'json',
success: function(j) {
loginResponse(j);
),
error: function() {
loginResponse();
}
});
return false;
});
});
笔记
else{...}
子句中的所有内容都如上所述进行了简化,因为''
和undefined
都是虚假的,因此只需测试foo
即可完成工作。 if(){...} else{...}
的三进制替代也使代码紧凑。
我不认为将类设置为返回的字符串是正确的做法,但是我没有改变这一方面。
首先,您可以尝试使用JavaScriptSerializer (链接该链接)将任何对象序列化为JSON,然后向客户端发送字符串响应。
对于服务器和客户端之间的通信,您可以使用jquery的ajax调用来调用Web服务(fe),或者,如果您构建ASP.NET网站或应用程序,则可以使用PageMethods并直接从javascript调用它。
如果您对PageMethods选项很感兴趣,那么这里是一个很好而又简单的教程 。
我终于写了:CS文件为
public string CreateLoginjson(string strErrorType, bool blIsAuthenticated)
{
StringBuilder sbLoginJson = new StringBuilder();
if (blIsAuthenticated)
{
sbLoginJson.Append("{LoginSuccess:1");
}
else
{
sbLoginJson.Append("{LoginSuccess:0");
}
if (strErrorType != string.Empty)
{
if (strErrorType.TrimEnd(new char[] { ',' }) == "Token" || strErrorType.TrimEnd(new char[] { ',' }).Split(new char[] { ',' }).Contains("BlankToken"))
{
sbLoginJson.Append(",txtTestTokenNumber1:\"Error\"");
sbLoginJson.Append(",txtTestTokenNumber2:\"Error\"");
sbLoginJson.Append(",txtTestTokenNumber3:\"Error\"");
sbLoginJson.Append(",txtTestTokenNumber4:\"Error\"");
}
if (strErrorType.TrimEnd(new char[] { ',' }) == "Password" || strErrorType.TrimEnd(new char[] { ',' }).Split(new char[] { ',' }).Contains("BlankPassword"))
{
sbLoginJson.Append(",txtPassword:\"Error\"");
}
if (strErrorType.TrimEnd(new char[] { ',' }) == "UserName" || strErrorType.TrimEnd(new char[] { ',' }).Split(new char[] { ',' }).Contains("BlankUserName"))
{
sbLoginJson.Append(",txtUserName:\"Error\"");
}
string strLoadErrorControlMessage = LoadErrorControl(strErrorType, string.Empty);
if (strLoadErrorControlMessage != string.Empty)
{
PageTestApplicationLogin objPageTestApplicationLogin = new PageTestApplicationLogin(objClientConfiguration);
sbLoginJson.Append(",ErrorMessage:'" + objPageTestApplicationLogin.GetTestApplicationLoginErrorHtml("", strLoadErrorControlMessage).Replace("'", "\"") + "'");
}
sbLoginJson.Append("}");
}
var LoginJson = sbLoginJson.ToString();
return LoginJson;
}
JS文件:
if (objLoginJson.ErrorMessage != '' && objLoginJson.ErrorMessage != undefined) {
$('#ErrorControl').html(objLoginJson.ErrorMessage);
$('#ErrorControl').find('#tblLoginError').css('display', 'block');
}
else {
$('#ErrorControl').html("");
$('#ErrorControl').find('#tblLoginError').css('display', 'none');
}
谢谢大家的建议。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.