javascript - 将字符串参数传递给 JavaScript 函数

标签 javascript c# asp.net webmethod

下面的代码我测试了很多次。它运行良好,我得到了“return photoMenu_sb.ToString();”的结果一旦我删除字符串参数 photoFileName。但是当我声明并尝试传递字符串 photoFileName 时,什么也没有发生。为什么?

我认为问题在于声明字符串 photoFileName 并将其传递给 javascript 函数,但我无法识别问题,因为我没有收到任何错误。是否有遗漏的引用?

[WebMethod]
public static string LoadPhotosPopup(int offset, int fetch, string IDuserInput)
{
        StringBuilder photosPopup_sb = new StringBuilder();           
        var photosPopup_query = db.Query("SELECT IDphoto], [photoFileName] FROM [photos] WHERE ([IDuser] = @0 AND [photoPublished] = 'True')  ORDER BY [photoDate] DESC OFFSET @1 ROWS FETCH NEXT @2 ROWS ONLY", IDuserInput, offset, fetch);
        foreach (var item in photosPopup_query)
        {
            var IDphoto = item.IDphoto;
            var photoFileName = item.photoFileName;
            photosPopup_sb.Append("<img src=\"Images/Design/openmenu.png\" onclick=\"photoMenu(" + IDphoto + ", '" + photoFileName + "') \" />");                         
         }           
        return photosPopup_sb.ToString();
    }

JavaScript

function photoMenu(IDphoto, photoFileName) {   
$.ajax({
    type: "POST",
    url: "UserControls/photosFunctions.aspx/photoMenu",
    data: "{ IDphoto: " + IDphoto + "}",
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    success: function (data) {
        $("#CommentsMenu" + IDphoto).html(data.d);
    }
})

}

[WebMethod]
            {   StringBuilder photoMenu_sb = new StringBuilder();                        
        photoMenu_sb.Append("<label>Testing </label>");
        return photoMenu_sb.ToString();
    }

更新 由于 public static string photoMenu(int IDphoto, string photoFileName) 则需要 2 个参数

 data: "{ IDphoto: " + IDphoto + "}", in the javascript function should be 
 data: "{ IDphoto: " + IDphoto + ", photoFileName: '" + photoFileName + "'}",

最佳答案

尝试创建一个字符串变量来保存 javascript 函数字符串:

var img = String.Format("<img src='Images/Design/openmenu.png' onclick='photoMenu({0},'{1}')' />", item.IDphoto, item.photoFileName);
photosPopup_sb.Append(img);  

在 JavaScript 中,您还需要设置 photofileName 参数的 json 数据属性:

function photoMenu(IDphoto, photoFileName) {   
    $.ajax({
        type: "POST",
        url: "UserControls/photosFunctions.aspx/photoMenu",
        data: "{ IDphoto: " + IDphoto + ", photoFileName: '" + photoFileName + "'}",
        contentType: "application/json; charset=utf-8",
        dataType: "json",
        success: function (data) {
           $("#CommentsMenu" + IDphoto).html(data.d);
        }
    }); 
}

关于javascript - 将字符串参数传递给 JavaScript 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28237338/

相关文章:

javascript - "res.render"是做什么的,html 文件是什么样的?

C#:构造函数调用的顺序

javascript - 如何在 asp.net 中从 c# 运行 javascript

c# - 更改行终止符

javascript - 自动完成 "is not a function"

javascript - 表单验证 ASP.NET 中的整个页面

javascript - Angular firebase 不显示 key

java - 直接 Web 远程处理异步问题

javascript - 如何在不调用特定 css 的情况下隐藏特殊字符

c# - 服务器端 Blazor 中单个 EditForm 中的多个模型验证