我在应用程序中的所有Textformfield小部件中都有这种奇怪的行为,给定给定给出的输入,Caret将移动到ç/ç的前面,而不是在其后面移动(在Android和iOS上观察到)。除了那种奇怪的行为,如果我要插入一封新信,那将不会放在ç/ç的前面(人们可能会假设的b/c),不,它覆盖了ç /ç以一种奇怪的方式形成两个字母的混合,好像应用程序不知道实际上已经有一个字母了。请检查所附图片。
我可以确认这不是字体问题,也不是UTF。该字体能够显示Cedilla C,并且仅使用TextFormField构建新的Flutter应用程序将不会再现此问题。所以,我必须缺少一些东西。
我使用的是一个几乎基本的默认textformfield,而没有自定义的textedingcontroller。我不想为每个TextFormField实例化一个自定义的TextEditingController,以便将解决方法传递到它(例如检查Ç/ç和将其移动在其后面))B/C如前所述,我知道默认的TextFormfield可以与Cedilla一起工作正常c。我希望有人知道一些配置问题或其他问题。
这是一个符合此行为的TextFormField的示例:
TextFormField(
decoration: const InputDecoration(labelText: 'Name it'),
validator: (value) {
if (value!.isEmpty) {
return 'Name is missing';
}
// case: name already exists
final check = context.read<BookState>().when((books) {
if (books.any((e) => e.name == value)) {
return 'Name already exists';
}
}, empty: () => null);
// case: all good
return check;
},
onSaved: (value) => bookName = value!,
)
I have this strange behavior throughout all TextFormField widgets in my app that given a Ç or ç input the caret will move back in front of the Ç/ç instead of behind it (observed on Android and iOS). On top of that strange behavior, if I was to insert a new letter, that new letter wouldn't be placed in front of the Ç/ç (as one might assume b/c of the caret), no, it overwrites the Ç/ç in a strange way forming a mix of two letters as if the application didn't know that there's actually a letter already in place. Please check the attached pictures.
I can confirm that this is not a font issue nor an UTF one. The font is capable of displaying a cedilla c, and building a new flutter app with just a TextFormField will not reproduce this issue. So, I've got to be missing something.
I am using a pretty much basic default TextFormField without a custom TextEditingController. I do not want to instantiate a custom TextEditingController for each TextFormField in order to pass a workaround to it (like checking for Ç/ç and moving the caret behind it) b/c as mentioned I know that the default TextFormField works just fine with cedilla c. I hope somebody knows about maybe some config issue or whatnot.
Here's an example of a TextFormField that runs into this behavior:
TextFormField(
decoration: const InputDecoration(labelText: 'Name it'),
validator: (value) {
if (value!.isEmpty) {
return 'Name is missing';
}
// case: name already exists
final check = context.read<BookState>().when((books) {
if (books.any((e) => e.name == value)) {
return 'Name already exists';
}
}, empty: () => null);
// case: all good
return check;
},
onSaved: (value) => bookName = value!,
)
data:image/s3,"s3://crabby-images/703de/703de54abcb2dbc9ef52b5068d31998157943a58" alt="caret immediately placed in front of ç"
data:image/s3,"s3://crabby-images/fd5aa/fd5aa27442e12f5f86eb9b32fde44cefe1082ba6" alt="resulting in an odd overwriting"
发布评论
评论(2)
如果您转到 textfortfordfield 页面页面并进行测试,您会看到那个有正确的行为
If you go to TextFormField page and test it, you will see that have the correct behaviour
我最近更新了Flutter SDK以及一些新版本的依赖项。从那时起,问题就解决了,没有真正触摸Textformfield小部件。我想这是依赖性的错误。 Google_fonts可能是接受主要版本升级的候选人...
I recently updated the flutter sdk as well as some of my dependencies for a new release. The problem is resolved since then without having actually touched the TextFormField widgets. I guess it was a bug in a dependency. google_fonts could be a candidate which received a major version upgrade ...