Android как проверка текстового поля во флаттере? - PullRequest
3 голосов
/ 25 апреля 2019

Я бы хотел добиться Android как TextField проверка в Flutter.

Я пробовал TextField документы Flutter, а InputDecoration имеет свойство errorText, но отображает ошибку в нижней части textfield. Я хочу достичь чего-то вроде ниже в Flutter

enter image description here

Ответы [ 3 ]

4 голосов
/ 06 мая 2019

Вы можете использовать TextFormField вместе с пользовательским Tooltip внутри Stack для достижения этого эффекта.В свойстве decoration для TextFormField вы можете использовать свойство suffixIcon класса InputDecoration для передачи значка ошибки.

И вы можете использовать переменную bool, чтобы показать / скрытьсообщение всплывающей подсказки при возникновении ошибки проверки.

Пример кода для TextFormField:

  TextFormField(
    decoration: InputDecoration(
      //Set the different border properties for a custom design
      suffixIcon: IconButton(
        icon: Icon(Icons.error, color: Colors.red),
        onPressed: () {
          setState(() {
            showTooltip = !showTooltip; //Toggles the tooltip
          });
        },
      ),
    ),
    validator: (String value) {
      if(value.isEmpty) {
        setState(() {
          showTooltip = true; //Toggles the tooltip
        });
        return "";
      }
    }
  );

Вы можете обернуть вышеупомянутый код вместе с вашим пользовательским кодом виджета подсказки с помощью Stackдля достижения эффекта всплывающей подсказки об ошибке.

Ниже приведен быстрый рабочий пример.Вы можете создать свой собственный виджет всплывающей подсказки и использовать его в своем коде.

Пример:

class LoginAlternate extends StatefulWidget {
  @override
  _LoginAlternateState createState() => _LoginAlternateState();
}

class _LoginAlternateState extends State<LoginAlternate> {

  GlobalKey<FormState> _formKey = GlobalKey();
  bool showTooltip = false;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      backgroundColor: Colors.blueGrey,
      body: Container(
        padding: EdgeInsets.symmetric(
          horizontal: 100,
          vertical: 100
        ),
        child: Form(
          key: _formKey,
          child: Column(
            children: <Widget>[
              Stack(
                alignment: Alignment.topRight,
                overflow: Overflow.visible,
                children: <Widget>[
                  TextFormField(
                    decoration: InputDecoration(
                      filled: true,
                      fillColor: Colors.white,
                      border: OutlineInputBorder(
                        borderSide: BorderSide.none
                      ),
                      suffixIcon: IconButton(
                        icon: Icon(Icons.error, color: Colors.red,),
                        onPressed: () {
                          setState(() {
                            showTooltip = !showTooltip;
                          });
                        },
                      ),
                      hintText: "Password"
                    ),
                    validator: (value) {
                      if(value.isEmpty) {
                        setState(() {
                          showTooltip = true;
                        });
                        return "";
                      }
                    },
                  ),
                  Positioned(
                    top: 50,
                    right: 10,
                    //You can use your own custom tooltip widget over here in place of below Container
                    child: showTooltip
                    ? Container(
                      width: 250,
                      height: 50,
                      decoration: BoxDecoration(
                        color: Colors.white,
                        border: Border.all( color: Colors.red, width: 2.0 ),
                        borderRadius: BorderRadius.circular(10)
                      ),
                      padding: EdgeInsets.symmetric(horizontal: 10),
                      child: Center(
                        child: Text(
                          "Your passwords must match and be 6 characters long.",
                        ),
                      ),
                    ) : Container(),
                  )
                ],
              ),
              RaisedButton(
                child: Text("Validate"),
                onPressed: () {
                  _formKey.currentState.validate();
                },
              ),
            ],
          ),
        ),
      ),
    );
  }
}
2 голосов
/ 25 апреля 2019

Я думаю, вы говорите о ToolTip

Вы можете использовать эту библиотеку или пройти через флаттер doc

new Tooltip(message: "Hello ToolTip", child: new Text("Press"));

вы можете использовать библиотеку super_tooltip #

enter image description here

0 голосов
/ 25 апреля 2019

Вы можете настроить этот тип ошибки, используя виджет наложения. Ошибка может быть показана с помощью виджета наложения, а значок ошибки можно изменить с помощью inputDecoration of TextField.

Вот ссылка для понимания виджета наложения-- https://medium.com/saugo360/https-medium-com-saugo360-flutter-using-overlay-to-display-floating-widgets-2e6d0e8decb9

...