asp. net mvc core select2 раскрывающийся список автозаполнение ajax call - PullRequest
0 голосов
/ 05 августа 2020

У меня есть представление, в котором я пытаюсь реализовать автоматическое заполнение текстового поля / раскрывающегося поля. Я использую список, который запрашиваю.

Я следую этому примеру http://www.dotnetqueries.com/Article/159/how-to-implement-select2-with-ajax-and-json-in-asp-net-mvc, точка останова даже не попадает в метод в моем контроллере. Так что что-то не так с тем, как я это настроил, или с тем, как метод результата действия вызывается в контроллере.

using System.Collections.Generic;
using System.Linq;
using System.Web.Mvc;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;
using TestSelect2.Models;
using Controller = Microsoft.AspNetCore.Mvc.Controller;
    
    namespace TestSelect2.Controllers
    {
        public class HomeController : Controller
        {
            private readonly ILogger<HomeController> _logger;
    
            public HomeController(ILogger<HomeController> logger)
            {
                _logger = logger;
            }
    
            public IActionResult Index()
            {
                return View();
            }
    
          
            [Microsoft.AspNetCore.Mvc.HttpPost]
            [Microsoft.AspNetCore.Mvc.Route("/home/account-list")]
            public Microsoft.AspNetCore.Mvc.ActionResult GetAccounts(string q)
            {
                List<Account> accounts = new List<Account>();
                // Add parts to the list.
                accounts.Add(new Account() { Id = 1, AccountNumber = "MVP1" });
                accounts.Add(new Account() { Id = 1, AccountNumber = "MVP11" });
                accounts.Add(new Account() { Id = 1, AccountNumber = "ABC2" });
                accounts.Add(new Account() { Id = 1, AccountNumber = "ABC3" });
                accounts.Add(new Account() { Id = 1, AccountNumber = "XYZ3" });
                accounts.Add(new Account() { Id = 1, AccountNumber = "XYZ4" });
    
     
                        
                    if (!(string.IsNullOrEmpty(q) || string.IsNullOrWhiteSpace(q)))
                    {
                        accounts = accounts.Where(x => x.AccountNumber.ToLower().StartsWith(q.ToLower())).ToList();
                    }
                    return Json(new { items = accounts }, JsonRequestBehavior.AllowGet);
            }
          
    
        }
    }



    @{
        Layout = null;
    }
    <!DOCTYPE html>
    <html>
    <head>
        <meta name="viewport" content="width=device-width" />
        <title>Select2 DEMO</title>
        <link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.6-rc.0/css/select2.min.css" rel="stylesheet" />
        <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.6-rc.0/js/select2.min.js"></script>
    
        <script>
            $(document).ready(function () {
                $(".accountSelect").select2({
                    ajax: {
                        url: '/home/account-list',
                        width: 'resolve',
                        data: function (params) {
                            return {
                                q: params.term// search term
                            };
                        },
                        processResults: function (data) {
                            return {
                                results: data.items
                            };
                        },
                        minimumInputLength: 2,
                        width: 'resolve'
                    }
                });
     
            });
        </script>
        <style>
            body {
                margin: auto;
                width: 600px;
                padding: 50px;
            }
    
            .accountSelect {
                width: 400px;
            }
        </style>
    </head>
    <body>
    <form method="post">
    
        <select class="accountSelect"></select>
    </form>
    </body>
    </html>

Ответы [ 2 ]

1 голос
/ 06 августа 2020

Удаляет атрибут [HttpPost] действия GetAccounts. Так как ajax делает запрос на получение. А учебник, которому вы следуете, предназначен для asp.net, но не asp.net core, JsonRequestBehavior нет.

Примечание: select2model должен содержать id и text два свойства, иначе его нельзя будет распознать. Измените модель Account, как показано ниже:

public class Account
{
    public int Id { get; set; }
    public string Text { get; set; }
}

И действие контроллера, убедитесь, что идентификатор не может совпадать.

[Route("/home/account-list")]
public IActionResult GetAccounts(string q)
{
    List<Account> accounts = new List<Account>();
    // Add parts to the list.
    accounts.Add(new Account() { Id = 1, Text = "MVP1" });
    accounts.Add(new Account() { Id = 2, Text = "MVP11" });
    accounts.Add(new Account() { Id = 3, Text = "ABC2" });
    accounts.Add(new Account() { Id = 4, Text = "ABC3" });
    accounts.Add(new Account() { Id = 5, Text = "XYZ3" });
    accounts.Add(new Account() { Id = 6, Text = "XYZ4" });


    if (!(string.IsNullOrEmpty(q) || string.IsNullOrWhiteSpace(q)))
    {
        accounts = accounts.Where(x => x.Text.ToLower().StartsWith(q.ToLower())).ToList();
    }
    return Json(new { items = accounts });
}

Просмотр и сценарии:

@{
    Layout = null;
}
<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Select2 DEMO</title>
    <link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.6-rc.0/css/select2.min.css" rel="stylesheet" />
    <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.6-rc.0/js/select2.min.js"></script>

    <script>
        $(document).ready(function () {
            $(".accountSelect").select2({
                minimumInputLength: 2,
                ajax: {
                    url: '/home/account-list',
                    data: function (params) {
                        return {
                            q: params.term// search term
                        };
                    },
                    processResults: function (data) {
                        return {
                            results: data.items
                        }
                    },
                }
            });
        });
    </script>

    <style>
        body {
            margin: auto;
            width: 600px;
            padding: 50px;
        }

        .accountSelect {
            width: 400px;
        }
    </style>
</head>
<body>
    <form method="post">
        <select class="accountSelect"></select>
    </form>

</body>
</html>

Результат:

введите описание изображения здесь

0 голосов
/ 06 августа 2020

Вы можете попробовать следующее:

//1. Action Method Which Returns the data. 
public ActionResult GetSelect2Data(string query)
{
    //In Realtime This should come from the Database
    List<DropDownItem> collection = new List<DropDownItem>() {
        new DropDownItem(){ Value = 1,  Text = "Switzerland"},
        new DropDownItem(){ Value = 2,  Text = "Canada"},
        new DropDownItem(){ Value = 3,  Text = "Japan"},
        new DropDownItem(){ Value = 4,  Text = "Germany"},
        new DropDownItem(){ Value = 5,  Text = "Australia"},
        new DropDownItem(){ Value = 6,  Text = "United Kingdom"},
        new DropDownItem(){ Value = 7,  Text = "United States"},
        new DropDownItem(){ Value = 8,  Text = "Sweden"},
        new DropDownItem(){ Value = 9,  Text = "India"},
       new DropDownItem(){ Value = 10,  Text = "Russia"},
     };


        var searchResult = from c in collection
                           where c.Text.Contains(query, 
   StringComparison.CurrentCultureIgnoreCase)
                           select c;

        return Json(searchResult.ToList());
    }



///2. JS Method which binds any HTML Select as Select2 or Smart Select.   
///In the User Interface (.cshtml file)You may define a framework JS Function as  which could be used anywhere
function registerSelect2(dropDownSelector, ajaxUrl) {
$(dropDownSelector).select2({
    ajax: {
    url: ajaxUrl,
    dataType: 'json',
    delay: 10,
    type: 'GET',
    data: function (params) {
    return {
        query: params.term, // search term
    };
    }
    , processResults: function (data) {
    return {
    results: $.map(data, function (item) {
        return {
            id: item.value,
            text: item.text,
        };
    })
    };
    },
    cache: true,
},
    minimumInputLength: 3,
    allowHtml: true,
    allowClear: true
});
}


//3. Invoke the JS Function to make any particular Select a Select2. 
$(function () {
    //Just you need to pass the Selector of your control and the Ajax Url from which data has to be loaded
    registerSelect2("#ddlSelect2", "/user/GetSelect2Data");
});


//This is the Simple Select which's made a Select2 Control. Paste it somewhere in the UI
<select id="ddlSelect2"></select>
...