Flutter:聚焦下一个TextFormField在Modal中不起作用

8qgya5xd  于 2023-05-19  发布在  Flutter
关注(0)|答案(1)|浏览(159)

当用户按下键盘上的下一个按钮时,我想关注下一个TextFormField。但是,当我按下下下一个按钮时,键盘就消失了。没有焦点。这个问题是不是因为ShowModalBottomSheet-Function?
我该怎么解决?

showModalBottomSheet(
        context: context,
        builder: (builder) {
          return addSheet(this);
        });
Container addSheet(State state){

  return new Container(
    height: 400.0,
    color: Color(0xFF737373),
    child: new Container(
        decoration: new BoxDecoration(
            color: Colors.white,
            borderRadius: new BorderRadius.only(
                topLeft: const Radius.circular(8.0), topRight: const Radius.circular(8.0))),
        child: Padding(
            padding: EdgeInsets.all(15.0),
            child: new Column(
              children: [
                TextFormField(
                  decoration: InputDecoration(
                      labelText: 'Mushroom Type',
                      hintText: 'Golden Oysters'
                  ),
                  autofocus: true,
                  focusNode: _mushroomTypeFocus,
                  textInputAction: TextInputAction.next,
                  onFieldSubmitted: (String value) {
                    FocusScope.of(state.context).requestFocus(_cultureTypeFocus);
                  },
                ),
                TextFormField(
                  decoration: InputDecoration(
                      labelText: 'Culture Type',
                      hintText: 'liquid culture, bag culture'
                  ),
                  focusNode: _cultureTypeFocus,
                )
              ]
            ),

        )
    )
  );
}

final FocusNode _mushroomTypeFocus = new FocusNode();
final FocusNode _cultureTypeFocus = new FocusNode();

von4xj4u

von4xj4u1#

在initState中请求的焦点对我有效。

@override
void initState() {
  super.initState();

  myFocusNode = FocusNode();
  myFocusNode.requestFocus();
}

此外,由于您使用的是focusNode,因此不需要autofucus:true

相关问题