Użyto metody pobierania Api flurl.http

Aug 23 2020

Wzywam APi przy użyciu Flurl.http, który zawiera pole wartości i tekstu. Używam tego interfejsu API w narzędziu Picker!

async void method()
        {
            string url = "http://xxx.xxx.xxx.xx/api/QMSRejection/GetShiftMaster";
            IList<dynamic> list = await url.GetJsonListAsync();
            var modelList = new List<string>();
            
            foreach (var item in list)
            {
                modelList.Add(item.Text);
                
            }
            ShiftPicker.ItemsSource = modelList;

        }

to jest odpowiedź JSON, którą zapewnia api

{"Value":"SF2017-1","Text":"General Shift Head Office"},{"Value":"SF2017-2","Text":"Shift-A-1 (Day)"},{"Value":"SF2017-3","Text":"Shift-B-1 (Night)"},{"Value":"SF2017-4","Text":"Shift-C"},{"Value":"SF2017-5","Text":"Shift-9.00AM-6.00PM"},{"Value":"SF201711","Text":"Morning Shift (6.00 Am-3.00Pm)"},{"Value":"SF20171203","Text":"Shift 6:30AM to 3:00PM"},{"Value":"SF2018-1","Text":"General Shift Factory-1"},{"Value":"SF20182","Text":"Shift 10AM to 8PM"},{"Value":"SF20191","Text":"General Shift Factory-2"},{"Value":"SF20192","Text":"Shift 7:00AM to 4:00PM"},{"Value":"SF20193","Text":"Shift-A-2 (Day)"},{"Value":"SF20194","Text":"Shift-B-2 (Night)"}]

Otrzymuję dane poprawnie i mogę również pobrać wybrany element, ale problem polega na tym, że dodałem tylko pole tekstowe, ale potrzebuję również dostępu do pola wartości!

W tej chwili Kiedy muszę przekazać wybraną wartość z listy rozwijanej, mam tylko tekst i potrzebuję również powiązanego z nim pola wartości, aby móc go użyć! Wyświetlam tylko tekst, ale potrzebuję do niego dostępu!

Odpowiedzi

1 Jason Aug 23 2020 at 05:31

zgodnie z sugestią @Iria, najpierw zdefiniuj klasę modelu dla swoich danych

public class MyClass{
  public string Value{get;set;}
  public string Text{get;set}
}

następnie powiedz flurl, aby zwrócił klasę o jednoznacznie określonym typie zamiast używania dynamicznej

var data = await url.GetJsonAsync<List<MyClass>>();

następnie możesz powiązać swój selektor bezpośrednio z danymi

ShiftPicker.ItemsSource = data;
Iria Aug 23 2020 at 03:36

Zrobiłbym co następuje:

var results = await url.GetJsonListAsync();
var myClass =  JsonSerializer.Deserialize<IEnumerable<MyClass>>(results);

Następnie

public class MyClass{
public string Value{get;set;}
public string Text{get;set}
}

w myClass masz kolekcję obiektów, które mają wartość i tekst, wtedy masz związek między wartością i tekstem dla każdego obiektu