Flutter, как передать значение из одной функции в другую на другой странице

Я пытаюсь передать значение при нажатии кнопки. В коде я хочу передать значение из виджета кнопки в переменную другой страницы с именем pdfNo. Вот мой код:

FlatButton(
          padding: EdgeInsets.fromLTRB(2, 5, 5, 5),
          child: ListTile(
            leading: Icon(Icons.book, color: Color(0xFFEB3549)),
            title: Text('Book5'),
          ),
          onPressed: () {
            Navigator.push(
                context,
                MaterialPageRoute(
                builder: (context) => PDFPage() ));
            print('Pressed 6');
          },
        ),`

Это кнопка на первой странице, при нажатии. Я хотел бы передать значение дочерней функции, поэтому я создал переменную, но не могу понять, как это сделать дальше:

var pdfNo = 2;
bool _isLoading = true;
PDFDocument document;
@override
   void initState() {
      super.initState();
        changePDF(pdfNo);
        loadDocument();
         }

changePDF(value) async {
setState(() => _isLoading = true);
if (value == 1) {
  document = await PDFDocument.fromAsset('assets/sample2.pdf');
} else if (value == 2) {
  document = await PDFDocument.fromURL(
      "http://conorlastowka.com/book/CitationNeededBook-Sample.pdf");
} else {
  document = await PDFDocument.fromAsset('assets/sample.pdf');
}
setState(() => _isLoading = false);
}

Итак, я хотел бы передать int с кнопки на странице 1 Staleful Class в Stateful Class на второй странице, чтобы изменить PDF (здесь).

Пожалуйста, помогите мне. PS Новое в Flutter,Dart


person Maddox Mania    schedule 25.05.2020    source источник


Ответы (2)


Вы можете создать to аргументы...

Что-то вроде этого

class LoginWidgetArguments {
  final String username;

  LoginWidgetArguments(
      {this.username});
}
class LoginWidget extends StatefulWidget {
  @override
  State<StatefulWidget> createState() => _LoginWidgetState();
}

class _LoginWidgetState extends State<LoginWidget>{
  LoginWidgetArguments args;

  @override
  void initState() {
    //Get context
    // I do this because sometimes it doesn't get the context without the FutureDelay... This workaround I used with the first flutter versions, maybe now its not needed
    Future.delayed(Duration.zero, () {
      args = ModalRoute.of(context).settings.arguments;
      if (args != null) {
        print(args.username)
      }
    });
  }

....
}

И для навигации

Navigator.pushNamed(context, LoginPage.routeName,
                    arguments: LoginWidgetArguments(
                        user: "[email protected]");

Редактировать

Может быть, это было бы просто...

FlatButton(
          padding: EdgeInsets.fromLTRB(2, 5, 5, 5),
          child: ListTile(
            leading: Icon(Icons.book, color: Color(0xFFEB3549)),
            title: Text('Book5'),
          ),
          onPressed: () {
            Navigator.push(
                context,
                MaterialPageRoute(
                builder: (context) => PDFPage(pageNumber: 6) ));
            print('Pressed 6');
          },
        )
class PDFPage extends StatefulWidget {
  final int pageNumber;
  PDFPage({this.pageNumber});
  @override
  _PDFPageStage createState() => _PDFPageStage();
}

class _PDFPageStage extends State<PDFPage> {
...
    @override
   void initState() {
      super.initState();
      changePDF(widget.pageNumber);
      loadDocument();
   }
...
}
person jjchiw    schedule 25.05.2020
comment
Спасибо. Итак, я должен создать класс для передачи аргументов в средство просмотра PDF. Не могли бы вы поделиться фрагментом моего кода? Я создаю приложение, в котором после нажатия кнопки оно переносит значение на другую страницу и передает его переменной, чтобы ее можно было использовать для изменения файлов PDF. - person Maddox Mania; 26.05.2020
comment
Второй сработал, спасибо, я только начал кодировать, и это работает :) - person Maddox Mania; 26.05.2020

Я не уверен, правильно ли я понимаю проблему, но я думаю, что вы можете передать число конструктору StatefulWidget. Я изменил PDFDocument на String для простоты.

Нажатие какой-то кнопки на первой странице:

onPressed: () {
  Navigator.push(
    context,
    MaterialPageRoute(
      builder: (context) => PDFPage(pdfNo: 4),
    ),
  );
},

Вторая страница:

class PDFPage extends StatefulWidget {
  final int pdfNo;

  const PDFPage({Key key, this.pdfNo}) : super(key: key);
  @override
  _PDFPageState createState() => _PDFPageState();
}

class _PDFPageState extends State<PDFPage> {
  bool _isLoading = false;
  String _document;

void changePDF(int value) async {
  setState(() => _isLoading = true);
  if (value == 1) {
    _document = await Future.delayed(Duration(seconds: 1), () => 'Value 1');
  } else if (value == 2) {
    _document = await Future.delayed(Duration(seconds: 1), () => 'Value 2');
  } else {
    _document = await Future.delayed(Duration(seconds: 1), () => 'Other value');
  }
  setState(() => _isLoading = false);
}

  @override
  void initState() {
    super.initState();
    changePDF(widget.pdfNo);
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: Text('Test'),),
          body: Center(
       child: _isLoading ? CircularProgressIndicator() : Text(_document ?? '(null)'), 
      ),
    );
  }
}
person gugge    schedule 25.05.2020
comment
Благодарю вас! @гугге - person Maddox Mania; 26.05.2020