0

.net Webサービスからjqueryに整数値を渡すと、ブール値として返されます。

私のウェブサービス:

     <WebMethod()> _
Public Shared Function returnRowId(ByVal User As String, ByVal ProgramName As String, Lesson As String) As Boolean
    Dim RowId As Integer
    Try
        Dim ds As New progressTableAdapters.Progress_LessonsTableAdapter
        RowId = ds.InsertFirstEntry(Lesson, Now, User, "", ProgramName)
    Catch ex As Exception
        RowId = 0
    End Try
    Return RowId
End Function

これがROWIDを返すSQLコードです」

    INSERT INTO Progress_Lessons
                  ( Lesson, Start_Time, User_Name, IPAddress, Programs)
    VALUES     (@lesson,@start,@user,@IP,@Programs);
    SELECT     SCOPE_IDENTITY()

これが、Webサービスを呼び出してROWIDをキャプチャする私のajaxコードです。

     function returnRowId() {
    var dataString = {
        User: $('#lblUser').val(),
        ProgramName: 'Conditional Statements',
        Lesson: $('#lblLesson').val()
    };
    var options = {
        type: "POST",
        url: 'cs.aspx/returnRowId',
        data: JSON.stringify(dataString),
        contentType: 'application/json; charset=utf-8',
        dataType: 'JSON',
        success: function (msg) {
            $('#rowId').val(msg.d);
        },
        error: function (request, status, error) {
                          alert(request.responseText);
                           alert(status.toString);
        }
    };
    $.ajax(options);
}

デバッグすると、webmethodの戻り値は正当な行番号です。ただし、jqueryコードの値をデバッグすると、msg.d=trueと表示されます。行の値がブール値に変換される理由がわかりません。

アドバイスをいただければ幸いです。

4

1 に答える 1

0

returnRowIdとして宣言されているas Booleanため、RowIdは応答に書き込まれる前に変換されます。

于 2012-03-05T17:37:21.097 に答える