ASP.NET MVC 및 jqGrid 드롭다운 목록 데이터 형식 지정: $.post 호출 문제 해결
ASP.NET MVC에서는 jqGrid의 편집 데이터 드롭다운 목록을 동적으로 채울 수 있습니다. 그러나 드롭다운 목록에 "정의되지 않은" 값이 나타나는 문제가 발생할 수 있습니다. 이는 jqGrid의 데이터 형식화로 인해 발생할 수 있습니다.
문제 개요
jQuery를 사용하여 $.post 호출을 수행할 때 컨트롤러에서 수신된 데이터에 큰따옴표가 포함될 수 있습니다. 이는 드롭다운 값이 "value:value;..." 형식일 것으로 예상하기 때문에 jqGrid에 문제를 일으킵니다.
해결책: ContentResult 사용
이 문제를 해결하려면 Json 대신 ContentResult 메서드를 사용하세요. ContentResult의 구문은 다음과 같습니다.
<code class="language-csharp">return Content(sb.ToString());</code>
대안: dataUrl 및 buildSelect 사용
또 다른 옵션은 jqGrid의 editoptions 또는 searchoptions에서 dataUrl 및 buildSelect 속성을 사용하는 것입니다. dataUrl을 사용하여 jqGrid의 선택 요소에 필요한 형식으로 데이터를 반환하는 URL을 제공합니다. buildSelect는 데이터를 수신하고 select 요소의 HTML을 반환하는 사용자 정의 함수입니다.
코드 예시
다음은 dataUrl 및 buildSelect를 사용하는 방법의 예입니다.
컨트롤러 작업:
<code class="language-csharp">public JsonResult GetDestinationList() { List<string> allDestinations = GetAllDestinations(); return Json(allDestinations, JsonRequestBehavior.AllowGet); }</code>
jqGrid 옵션:
<code class="language-javascript">{ name: 'destinations', editable: true, edittype:'select', editoptions: { dataUrl: '/YourController/GetDestinationList', buildSelect: function(data){ var s = '<select>'; if (data && data.length) { for (var i = 0, l=data.length; i<l ; i++) { var ri = data[i]; s += '<option value="' + ri + '">' + ri + '</option>'; } } s += '</select>'; return s; }} }</code>
요약
ContentResult 메서드나 dataUrl 및 buildSelect 속성을 사용하여 ASP.NET MVC의 $.post 호출에서 jqGrid 드롭다운 값에 올바른 데이터 형식을 제공할 수 있습니다.
위 내용은 ASP.NET MVC $.post 호출에서 jqGrid 드롭다운 응답의 형식을 올바르게 지정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!