Начинаю создавать iOS-приложение интернет-магазина с подключением к сайту на Woocommerce. Я хочу вставить в TableView продукты из Woocommerce через API.
Теперь я создаю приложение, симулятор запускает только белый пустой экран. В конечном результате я хочу запустить iOS-приложение с подключением к сайту на Woocommerce, но я создаю его шаг за шагом, и первым шагом сейчас я хочу сделать экран с товаром или категориями из этого магазина. Почему в моем приложении iOS отображается пустой экран, когда я пытаюсь отобразить продукты WooCommerce в TableView через API?
Product.swift
struct Product: Codable {
let id: Int
let name: String
let price: String
let regular_price: String?
let sale_price: String?
let description: String?
let short_description: String?
let images: [ProductImage]?
}
struct ProductImage: Codable {
let src: String
}
ViewController.swift
ViewController.swift
import UIKit
class ViewController: UIViewController {
@IBOutlet weak var tableView: UITableView!
private let api = WooCommerceAPI()
private var products: [Product] = []
override func viewDidLoad() {
super.viewDidLoad()
fetchProducts()
}
func fetchProducts() {
let urlString = "https:///wp-json/wc/v3/products"
guard let url = URL(string: urlString) else { return }
URLSession.shared.dataTask(with: url) { data, response, error in
// 1. Проверка ошибок
if let error = error {
print("Ошибка сети: \(error)")
return
}
// 2. Обработка данных
guard let data = data else { return }
do {
// Здесь декодируйте JSON (например, в массив продуктов)
print("Данные получены: \(data)")
} catch {
print("Ошибка декодирования: \(error)")
}
}.resume()
}
}
WoocommerceAPI.swift
import Foundation
class WooCommerceAPI {
private let baseURL = "https://wp-json/wc/v3"
private let consumerKey = "ck_1255d3fa39b33e661fc91e9fe17dd16fb4367e5"
private let consumerSecret = "cs_707ff6ee2e25206a2858c5f288f57dd18acf8358"
func fetchProducts(completion: @escaping ([Product]?) -> Void) {
let endpoint = "\(baseURL)/products"
let urlString = "\(endpoint)?consumer_key=\(consumerKey)&consumer_secret=\(consumerSecret)"
guard let url = URL(string: urlString) else {
completion(nil)
return
}
URLSession.shared.dataTask(with: url) { data, response, error in
if let error = error {
print("Ошибка: \(error.localizedDescription)")
completion(nil)
return
}
guard let data = data else {
completion(nil)
return
}
do {
let products = try JSONDecoder().decode([Product].self, from: data)
completion(products)
} catch {
print("Ошибка декодирования: \(error.localizedDescription)")
completion(nil)
}
}.resume()
}
}
Подробнее здесь: https://stackoverflow.com/questions/798 ... p-with-api