簡體   English   中英

從jquery渲染部分視圖不工作

[英]render partial view from jquery not working

我有一些使用jquery渲染局部視圖的問題。 即使它不止一次被問到( 這里 ),我也沒有找到適合我的解決方案:我的觀點:

@model IEnumerable<OdeToFood.Models.RestaurantListViewModel>

@{
    ViewBag.Title = "Home Page";
}

<form method="get" action="@Url.Action("Index")" data-otf-ajax="true" data-otf-target="#restaurantlist">
    <input type="search" name="searchTerm" />
    <input type="submit" value="Search By Name" />

</form>

@Html.Partial("_Restaurants", Model)

我的部分觀點:

@model IEnumerable<OdeToFood.Models.RestaurantListViewModel>

<div id="restaurantList">

    @foreach (var item in Model)
    {
        <div>
            <h4>@item.Name</h4>
            <div>@item.City, @item.Country</div>
            <div>REviews: @item.CountOfReviews</div>
            <hr />
        </div>
    }
</div>

otf.js:

$(function () {

    var ajaxFormSubmit = function () {
        var $form = $(this);

        var options = {
            url: $form.attr("action"),
            type: $form.attr("method"),
            data: $form.serialize()
        };

        $.ajax(options).done(function (data) {
            var $target = $($form.attr("data-otf-target"));
            $target.replaceWith(data);
        });

        return false;
    };

    $("form[data-otf-ajax='true']").submit(ajaxFormSubmit);
});

我的控制器的索引動作:

 public ActionResult Index(string searchTerm = null)
        {
            var model =
                _db.Restaurants
                .OrderByDescending(r => r.RestaurantReviews.Average(a => a.Rating))                
                .Where(r => searchTerm == null || r.Name.StartsWith(searchTerm))
                .Select(r => new RestaurantListViewModel
                {
                    Id = r.Id,
                    Name = r.Name,
                    City = r.City,
                    Country = r.Country,
                    CountOfReviews = r.RestaurantReviews.Count()
                }
                )
                .Take(10);

            if (Request.IsAjaxRequest())
            {
                return PartialView("_Restaurants", model);
            }

            return View(model);
        }

我的問題是當我按下搜索按鈕時沒有任何反應。 我添加了一個測試提醒,例如:

$.ajax(options).done(function (data) {
            var $target = $($form.attr("data-otf-target"));
            alert('test');
            $target.replaceWith(data);
        });

當我點擊搜索按鈕時,警報顯示,但在網站上沒有任何反應。 誰知道我的問題是什么?

你有#restaurantlist作為目標,而div id實際上是restaurantList 資本“L”。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM