当通过jQuery调用时,WebAPI Controller重定向到原始JSON视图

时间:2014-11-19 00:23:45

标签: javascript jquery json asp.net-web-api kendo-ui

我有一个ASP.NET MVC应用程序。我正在尝试调用WebAPI控制器。当我通过jQuery中的$ .get调用它时,控制器工作正常。完成回调功能后,一切都应该停止,我应该能够看到我的网页。但是,在完成回调函数后,浏览器将我带到chrome中的原始JSON视图页面。在IE中,它询问我是否要下载返回的.json文件。为什么会这样呢?这是我的代码:

function onNLookupSearch() {
    var uri = window.location.protocol + "//" + window.location.host;
    var searchTerm = $("#nlookupsearch").val();
    var resultUrl = window.location.href = uri + "/api/v1/GetNetworkName?networkName=" + searchTerm;
    $.get(resultUrl, function (data1) {
        localData1 = data1;

        $("#sdnetworkselect").kendoDropDownList({
            dataSource: localData1,
            dataTextField: "NETWORK_NAME",
            dataValueField: "NETWORK_ID"
        });
        $("#hdnetworkselect").kendoDropDownList({
            dataSource: localData1,
            dataTextField: "NETWORK_NAME",
            dataValueField: "NETWORK_ID"
        });
      });
    }

这是我的WebAPI控制器代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web.Http;
using CPT2.Data;

namespace CPT2.Controllers
{
    public class GetNetworkNameController : ApiController
    {
        private CMDBdbContext _ctx;

        public GetNetworkNameController(CPT2.Data.CMDBdbContext ctx)
        {
            _ctx = ctx;
        }

        public IQueryable<CPT2.Data.network_sourceid_map> Get([FromUri] string networkName)
        {
            var result =
                _ctx.network_sourceid_map.Where(
                    nw => nw.NETWORK_NAME.Contains(networkName) || nw.SOURCE_NAME.Contains(networkName));
            var myList = result.Select(item => item.NETWORK_NAME + " - " + item.SOURCE_NAME + " [" + item.SOURCE_ID + "]").ToList();
            //return myList;
            return result;
        }
    }
}

让我们假设我搜索&#34; ESPN&#34;。这是上面代码中的搜索字词。

完成此功能后,我应该留在页面上但是我被重定向到Chrome和IE返回数据的原始视图,要求我保存JSON文件。

1 个答案:

答案 0 :(得分:1)

我认为你的问题就在这一行:

var resultUrl = window.location.href = uri + "/api/v1/GetNetworkName?networkName=" + searchTerm;

您正在设置window.location.href,它将整个页面重定向到API&#34; page&#34;,这就是您获取.json文件的原因。