Ottieni il metodo Api flurl.http utilizzato

Aug 23 2020

Sto chiamando un APi utilizzando Flurl.http che contiene il campo Valore e Testo. Sto usando quell'API in 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;

        }

questa è la risposta JSON fornita dall'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)"}]

Sto ottenendo i dati correttamente e sono in grado di recuperare anche l'elemento selezionato, ma il problema è che ho aggiunto solo il campo di testo ma ho bisogno anche dell'accesso al campo del valore!

In questo momento Quando devo passare il valore selezionato del menu a discesa, ho solo il testo e ho bisogno anche del campo del valore associato per poterlo usare! Visualizzerò solo il testo ma ho bisogno di accedervi!

Risposte

1 Jason Aug 23 2020 at 05:31

come suggerito da @Iria, definisci prima una classe modello per i tuoi dati

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

quindi dire a flurl di restituire una classe fortemente tipizzata invece di usare dynamic

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

quindi puoi associare il tuo selettore direttamente ai dati

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

Farei quanto segue:

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

Quindi

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

in miaClasse hai una collezione di oggetti che hanno Valore e Testo, quindi hai la corrispondenza tra valore e Testo per ogni oggetto