TextField 光标位置 Flutter WEB

Posted

技术标签:

【中文标题】TextField 光标位置 Flutter WEB【英文标题】:TextField Cursor Position Flutter WEB 【发布时间】:2021-05-22 03:55:44 【问题描述】:

这段代码的作用是在您单击光标时打印光标在文本中的位置。

  TextEditingController controller = TextEditingController();

  @override
  Widget build(BuildContext context) 
    return Scaffold(
      appBar: AppBar(
        title: Text(
          widget.title,
        ),
      ),
      body: TextField(
        controller: controller,
        keyboardType: TextInputType.multiline,
        maxLines: null,
        onTap: () 
          int pos = controller.selection.start;
          print(
            "Position: $pos",
          );
        ,
      ),
    );
  

但问题是这是针对网络的,所以我需要它在光标移动时说出光标的位置,而不仅仅是在我点击它时。 我的意思是如果你用键盘移动光标,它也应该打印位置。

我已经尝试过使用 GestureDetector 和 Focus,但什么也没有。知道我可以使用什么吗?

更新: 我找到的解决方案如下,它完美地满足了我的需要:

TextEditingController controller = TextEditingController();

int cursorPosition = 0;

@override
void initState() 
  controller.addListener(() 
    setState(() 
      cursorPosition = controller.selection.base.offset;
      print("cursorPosition: $cursorPosition");
    );
  );
  super.initState();


@override
Widget build(BuildContext context) 
  return Scaffold(
    appBar: AppBar(
      title: Text(
        widget.title,
      ),
    ),
    body: TextField(
      controller: controller,
      keyboardType: TextInputType.multiline,
      maxLines: null,
    ),
  );

完整代码:

    import 'package:flutter/material.dart';
import 'package:flutter/services.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget 
  @override
  Widget build(BuildContext context) 
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  


class MyHomePage extends StatefulWidget 
  MyHomePage(Key key, this.title) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();


class _MyHomePageState extends State<MyHomePage> 
  TextEditingController controller = TextEditingController();

  int cursorPosition = 0;

  @override
  void initState() 
    controller.addListener(() 
      setState(() 
        cursorPosition = controller.selection.base.offset;
        print("cursorPosition: $cursorPosition");
      );
    );
    super.initState();
  

  @override
  Widget build(BuildContext context) 
    return Scaffold(
      appBar: AppBar(
        title: Text(
          widget.title,
        ),
      ),
      body: TextField(
        controller: controller,
        keyboardType: TextInputType.multiline,
        maxLines: null,
      ),
    );
  

【问题讨论】:

【参考方案1】:

我找到的解决方案如下,它可以完美地满足我的需要:

TextEditingController controller = TextEditingController();

int cursorPosition = 0;

@override
void initState() 
  controller.addListener(() 
    setState(() 
      cursorPosition = controller.selection.base.offset;
      print("cursorPosition: $cursorPosition");
    );
  );
  super.initState();


@override
Widget build(BuildContext context) 
  return Scaffold(
    appBar: AppBar(
      title: Text(
        widget.title,
      ),
    ),
    body: TextField(
      controller: controller,
      keyboardType: TextInputType.multiline,
      maxLines: null,
    ),
  );

完整代码:

    import 'package:flutter/material.dart';
import 'package:flutter/services.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget 
  @override
  Widget build(BuildContext context) 
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  


class MyHomePage extends StatefulWidget 
  MyHomePage(Key key, this.title) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();


class _MyHomePageState extends State<MyHomePage> 
  TextEditingController controller = TextEditingController();

  int cursorPosition = 0;

  @override
  void initState() 
    controller.addListener(() 
      setState(() 
        cursorPosition = controller.selection.base.offset;
        print("cursorPosition: $cursorPosition");
      );
    );
    super.initState();
  

  @override
  Widget build(BuildContext context) 
    return Scaffold(
      appBar: AppBar(
        title: Text(
          widget.title,
        ),
      ),
      body: TextField(
        controller: controller,
        keyboardType: TextInputType.multiline,
        maxLines: null,
      ),
    );
  

【讨论】:

【参考方案2】:
onChanged: (value) 
      int pos = controller.selection.start;
      print(
        "Position: $pos",
      );
    ,

【讨论】:

它不起作用,当您用键盘移动光标时,它不会将其视为更改,因此不会打印任何内容

以上是关于TextField 光标位置 Flutter WEB的主要内容,如果未能解决你的问题,请参考以下文章

Flutter TextField 文本输入框的基本属性及详解

Flutter:使用初始值文本时如何隐藏TextField文本指针(光标)(Android)

Flutter -TextField 控制器在文本之前获取我的光标

在 Flutter 中使用控制器设置文本时 TextField 光标不移动

Compose TextField设置光标位置

NSTextField 光标位置