Changing focus from one text field to the next in Flutter

前端 未结 4 1766
佛祖请我去吃肉
佛祖请我去吃肉 2021-02-05 03:40

I have two textFormField widgets. Once the user has completed the first text field I would like to focus on the next textField. Is there a way to do

相关标签:
4条回答
  • 2021-02-05 03:55

    Screenshot:


    No need to use FocusNode

    @override
    Widget build(BuildContext context) {
      return Scaffold(
        appBar: AppBar(),
        body: Column(
          children: [
            TextField(
              decoration: InputDecoration(hintText: 'First Name'),
              textInputAction: TextInputAction.next,
              onEditingComplete: () => FocusScope.of(context).nextFocus(),
            ),
            TextField(
              decoration: InputDecoration(hintText: 'Last Name'),
              textInputAction: TextInputAction.done,
              onSubmitted: (_) => FocusScope.of(context).unfocus(),
            ),
          ],
        ),
      );
    }
    
    0 讨论(0)
  • 2021-02-05 04:02

    Yes, FocusNode and the onFieldSubmitted from a TextFormField are probably the way to go.

    FocusScope.of(context).requestFocus(focusNode);

    Here is an example that may help:

        FocusNode textSecondFocusNode = new FocusNode();
    
        TextFormField textFirst = new TextFormField(
          onFieldSubmitted: (String value) {
            FocusScope.of(context).requestFocus(textSecondFocusNode);
          },
        );
    
        TextFormField textSecond = new TextFormField(
          focusNode: textSecondFocusNode,
        );
    
        // render textFirst and textSecond where you want
    

    You may also want to trigger FocusScope.of() from a button rather than onFieldSubmitted, but hopefully the above example gives you enough context to construct an appropriate solution for your use case.

    0 讨论(0)
  • 2021-02-05 04:10

    There's a similar method like in Android.

    Add

    textInputAction
    

    parameter to the TextFormField Widget, then add the property as;

     TextInputAction.next
    
    0 讨论(0)
  • 2021-02-05 04:12

    This is how I did it:

      var _focusNodes = List.generate(6, (index) => FocusNode()));
    

    And in the TextFormField:

      TextFormField(
        focusNode: _focusNodes[i],
        maxLines: 1,
        textInputAction: TextInputAction.next,
        onChanged: (text) {
          if (i < _controllers.length) {
            if (text.isEmpty)
              _focusNodes[i - 1].requestFocus();
            else
              _focusNodes[i + 1].requestFocus();
          }
        },
      ),
    
    0 讨论(0)
提交回复
热议问题