여기에 약간의 문제가 있습니다. 코드가 잘 보이지만 응용 프로그램이 WebAPI 데이터베이스에 삽입하고있는 올바른 목록을 바인딩하지 않습니다. 내가 달성하기 위해 무엇을 기대C# ListView 응용 프로그램에서 JSON 나머지 API를 사용하여 웹 API 문의 - 안드로이드가 공백 반환
:
여기는 JSON입니다 :
크로스 플랫폼의 목록보기, 나는 안드로이드에서 테스트하고있어이 경우, 그것은 다음과 같은 WebAPI 코드에있는 모든 데이터를 나열
namespace Icquire.RestClient
{ public class RestClient<T>
{
private const string WebServiceUrl = "http://localhost:58173/api/BusinessRegs/";
public async Task<List<T>> GetAsync()
{
var httpClient = new HttpClient();
var json = await httpClient.GetStringAsync(string.Format(WebServiceUrl));
var BusinessReg = JsonConvert.DeserializeObject<List<T>>(json);
return BusinessReg;
}
public async Task<bool> PostAsync(T t)
{
var httpClient = new HttpClient();
var json = JsonConvert.SerializeObject(t);
HttpContent httpContent = new StringContent(json);
httpContent.Headers.ContentType = new MediaTypeHeaderValue("application/json");
var result = await httpClient.PostAsync(WebServiceUrl, httpContent);
return result.IsSuccessStatusCode;
}
public async Task<bool> PutAsync(int Id, T t)
{
var httpClient = new HttpClient();
var json = JsonConvert.SerializeObject(t);
HttpContent httpContent = new StringContent(json);
httpContent.Headers.ContentType = new MediaTypeHeaderValue("application/json");
var result = await httpClient.PostAsync(WebServiceUrl + Id, httpContent);
return result.IsSuccessStatusCode;
}
public async Task<bool> DeleteAsync(int Id, T t)
{
var httpClient = new HttpClient();
var response = await httpClient.DeleteAsync(WebServiceUrl + Id);
return response.IsSuccessStatusCode;
}
}}
다음 WebAPI 여기
[{"Id":1,"BusinessName":"La ventana","BusinessFantasyName":"La Ventana","BusinessArea":"Restaurante","BusinessSpecificArea":"Pizzaria","Country":"Brasil","State":"RS","City":"Rio Grande","Adress":"Av Rio Grande","Neighbourhood":"Cassino","Number":"134","Complement":"Casa","Latitude":-32.1853837,"Longitude":-52.1582284,"DateOfReg":"26/12/2017","DateOfMod":"26/12/2017","BusinessStatus":"Ativo","RegisteredBy":"Daniel Serrão"},{"Id":2,"BusinessName":"Supermercado Granabara - Cassino","BusinessFantasyName":"Supermercado Granabara - Cassino","BusinessArea":"Supermercados","BusinessSpecificArea":"Bens e Consumo","Country":"Brasil","State":"RS","City":"Rio Grande","Adress":"Av Rio Grande","Neighbourhood":"Cassino","Number":"150","Complement":"NA","Latitude":-32.1845922,"Longitude":-52.1591549,"DateOfReg":"26/12/2017","DateOfMod":"26/12/2017","BusinessStatus":"Ativo","RegisteredBy":"Daniel Serrão"}]
에 상장되어 파일이 WEBAPI를 참조하기 위해 코드를입니다
namespace Icquire.Services
{ public class BusinessRegServices
{ public async Task<List<BusinessReg>> GetBusinessRegAsync()
{
RestClient<BusinessReg> restClient = new RestClient<BusinessReg>();
var BusinessRegList = await restClient.GetAsync();
return BusinessRegList;
}
}
} 여기
이 데이터를보기 위해 코드를 다음과 같습니다 :여기내부 서비스에 대한 코드입니다
namespace Icquire.ViewModel
{ public class BusinessRegView : INotifyPropertyChanged
{
private List<BusinessReg> _BusinessRegList
{
get { return _BusinessRegList; }
set
{
_BusinessRegList = value;
OnPropertyChanged();
}
}
public List<BusinessReg> BusinessRegList { get; set; }
public BusinessRegView()
{
InitializeDataAsync();
}
private async Task InitializeDataAsync()
{
var businessRegServices = new BusinessRegServices();
BusinessRegList = await businessRegServices.GetBusinessRegAsync();
}
public event PropertyChangedEventHandler PropertyChanged;
protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null)
{
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}
};
} 여기
그리고는 내 contentPage의 ListView :
<ListView ItemsSource="{Binding BusinessRegList}" HasUnevenRows="True" >
<ListView.ItemTemplate>
<DataTemplate>
<ViewCell>
<StackLayout Orientation ="Vertical">
<Label TextColor="Silver" Text="{Binding BusinessName}"/>
<Label TextColor="Silver" Text="{Binding Adress}"/>
<Label TextColor="Silver" Text="{Binding Number}"/>
</StackLayout>
</ViewCell>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
위 코드를 사용하면 ListView의 바인딩이 공백으로 반환됩니다. Json이 corretly을 생성 할 때 나는 문제가 Json 파일에 대한 컨설팅에 있다고 생각한다. 또는 서비스 코드 내부. 아무도 단서가 있습니까?
미리 감사드립니다 ... 다니엘.
불행히도 작동하지 않았습니다. 변경 후에도 App이 실행되지 않았습니다. –