Преобразование for in в GridView.builder во Flutter - PullRequest
0 голосов
/ 16 июня 2020

Я хочу преобразовать свой for in l oop в GridView.builder. Как я могу этого добиться? Я получаю от API. Я фильтрую тег изображения из содержимого HTML.

import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'dart:convert';
import 'dart:async';
import 'package:html/parser.dart' show parse;
import 'package:html/dom.dart' as dom;

Future<List> fetchWpPosts() async {
  final response = await http.get(
      'https://soleentrepreneur.co.uk/wp-json/w/v1/trending',
      headers: {"Accept": "application/json"});
  var convertDatattoJson = jsonDecode(response.body);
  return convertDatattoJson;
}

class WordPressContentImageDynamic extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      body: Container(
        child: FutureBuilder(
          builder: (context, snapshot) {
            if (snapshot.hasData) {
              return ListView.builder(
                  // gridDelegate: new SliverGridDelegateWithFixedCrossAxisCount(
                  //     crossAxisCount: 3),
                  itemBuilder: (context, index) {
                    Map wppost = snapshot.data[index];

                    String jsonString = '''${wppost['content']}''';
                    String result = jsonString.replaceAll("\n", "\\n");
                    String result2 = result.replaceAll("\\n", "");
                    var document = parse(result2);
                    var imgList = document.querySelectorAll("img");
                    // return (imgList.isEmpty)
                    //     ? Text('data')
                    //     : Text(imgList.toString());
                    return Column(
                      children: <Widget>[
                        (imgList.isEmpty)
                            ? Text('data')
                            : Text(imgList.toString()),
                        for (dom.Element img in imgList)
                          Image.network(img.attributes["src"]),
                      ],
                    );
                  },
                  itemCount: snapshot.data.length);
            }
            return CircularProgressIndicator();
          },
          future: fetchWpPosts(),
        ),
      ),
    );
  }
}


...