- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个简单的应用程序,它包含以下屏幕:
登陆屏幕登录屏幕验证屏幕
当尝试在验证屏幕上写东西时,当键盘出现并且文本字段获得焦点时,键盘会自动关闭,它会将我导航回登录屏幕而不会出现任何错误或错误。我不知道为什么会这样?
信息:我在物理机和模拟器上运行应用程序,但没有任何区别,flutter 版本是 2.0.3,dart 2.12.2
这里是 flutter 医生:
Doctor summary (to see all details, run flutter doctor -v):
[√] Flutter (Channel stable, 2.0.3, on Microsoft Windows [Version
10.0.18363.1440], locale en-US)
[√] Android toolchain - develop for Android devices (Android SDK version
30.0.3)
[√] Chrome - develop for the web
[√] Android Studio (version 4.1.0)
[√] IntelliJ IDEA Ultimate Edition (version 2020.2)
[√] VS Code (version 1.53.2)
[√] Connected device (3 available)
这是main的代码库:
void main() async {
WidgetsFlutterBinding.ensureInitialized();
runApp(
MyApp(),
);
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return GetMaterialApp(
title:TextConstants.appName,
debugShowCheckedModeBanner: false,
home: LandingScreen(),
initialRoute: '/landing-screen',
defaultTransition: Transition.downToUp,
getPages: [
GetPage(
name: '/landing-screen',
page: () => LandingScreen(),
),
GetPage(
name: '/login-screen',
page: () => LoginScreen(),
),
GetPage(
name: '/verification-screen',
page: () => VerificationScreen(),
),
],
);
}
}
这是登陆屏幕的代码库:
@override
void didChangeDependencies() async {
super.didChangeDependencies();
if( await NetworkingUtils.checkInternetConnection()){
// if it's connected.
Get.toNamed("/login-screen");
} else {
// if it's not connected.
Get.snackbar(
'Warning', // title
'You don\'t have internet connection',
icon: Icon(Icons.warning,color: Colors.white,),
snackPosition: SnackPosition.BOTTOM,
borderRadius: 0,
showProgressIndicator: true,
mainButton: TextButton(onPressed: (){}, child: Text('Check')),
colorText: Colors.white,
forwardAnimationCurve: Curves.bounceIn,
isDismissible: false,
reverseAnimationCurve: Curves.easeInOut,
);
}
}
@override
Widget build(BuildContext context) {
double height = MediaQuery.of(context).size.height;
double width = MediaQuery.of(context).size.width;
return Scaffold(
backgroundColor: Colors.lightBlueAccent,
body: Container(
decoration: BoxDecoration(
image: DecorationImage(
image: AssetImage('assets/images/landing_background.png'),
fit: BoxFit.fill
)
),
child: Center(
child: Padding(
padding: const EdgeInsets.all(8.0),
child: AvatarGlow(
glowColor: Colors.white,
endRadius: width*0.44,
showTwoGlows: true,
repeat: true,
duration: Duration(milliseconds: 1000),
animate: true,
child: ClipRRect(
borderRadius: BorderRadius.circular(200.0),
child: Container(
height: width*0.6,
width: width*0.6,
child: Image.asset('assets/images/smart_city_logo.png'),
),
),
),
),
),
),
);
}
}
这是登录屏幕的代码库:
class LoginScreen extends StatefulWidget {
@override
_LoginScreenState createState() => _LoginScreenState();
}
class _LoginScreenState extends State<LoginScreen> {
TextEditingController _phoneNumberController = TextEditingController();
bool isLoading = false;
@override
Widget build(BuildContext context) {
double height = MediaQuery.of(context).size.height;
double width = MediaQuery.of(context).size.width;
return Scaffold(
backgroundColor: Colors.white,
body: SafeArea(
child: SingleChildScrollView(
child: Container(
padding: EdgeInsets.symmetric(horizontal: 20, vertical: 30),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Image.asset('assets/images/smart_city_logo_transparent.png',height: width/2.5,fit: BoxFit.fill,),
SizedBox(height: 15,),
Text("LOGIN TO", style: FontConstants.k24Light(fontSize: 38, textColor: Colors.black),),
Text("SMART CITY \nMANAGER", style: FontConstants.k24Bold(fontSize: 35, textColor: ColorConstant.blueLight),textAlign: TextAlign.start,),
Divider(height: 15,color: Colors.black, endIndent: width * 0.80, thickness: 3,),
Text("Smart city manager provides whole information about the flat that you are looking for.", style: FontConstants.k24Light(fontSize: 20, textColor: Colors.black ).copyWith(wordSpacing: 0.5),),
SizedBox(height: 35,),
TextField(
style: FontConstants.k24Light(fontSize: 20, textColor: Colors.black),
decoration: InputDecoration(
border: OutlineInputBorder(
borderRadius: BorderRadius.all(
Radius.circular(10)
),
borderSide: BorderSide(
width: 0,
style: BorderStyle.none
)
),
filled: true,
fillColor: ColorConstant.blueGreyLight,
prefixIcon: Icon(Icons.phone_android_sharp, color: Colors.grey,),
hintText: "Phone number...",
),
),
SizedBox(height: 35,),
RaisedGradientButton(
child: Text(
'NEXT',
style: FontConstants.k24Light(
fontSize: 28, textColor: Colors.white),
),
onPressed: () {
Get.toNamed('/verification-screen');
},
gradient: LinearGradient(
begin: Alignment.topCenter,
end: Alignment.bottomCenter,
colors: [
Color(0xff7CD9FF),
Color(0xff3CC6FF),
]),
)
],
),
),
),
),
);
}
}
这是最后一个仅包含一个文本字段的代码库:
class VerificationScreen extends StatefulWidget {
@override
_VerificationScreenState createState() => _VerificationScreenState();
}
class _VerificationScreenState extends State<VerificationScreen> {
@override
Widget build(BuildContext context) {
return Scaffold(
body: Container(
child: Center(
child: TextField(),
),
));
}
}
最佳答案
我在着陆屏幕上遇到了问题,它弄乱了小部件树。因为 didChangeDependancy 方法会被多次调用,并且会随着小部件树的任何更改而被调用。解决方案是 didChangeWidget 而不是 didChangeDependancy 并将导航更改为 offAndToNamed。
关于flutter - 当文本字段获得焦点并出现键盘时,为什么它会导航我回到上一个屏幕?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66905528/
我遇到了一个问题。我正在使用 pyinstaller 将代码导出到 .exe。代码包括 tkinter、PIL 和 keyboard 模块。软件在我使用 Python 的 PC 上运行完美,而在没有
我正在尝试将 STM32F0-disco 用作 Windows PC 的键盘。正在打印的字符有问题。 下面的代码等到板载按钮被按下,然后应该打印一次这三个字符。 /* USER CODE BE
我想在单击键盘上的“完成”按钮时退出键盘。我怎样才能做到这一点?我有以下代码=> textView.returnKeyType = UIReturnKeyDone; 我有这个代码用于限制 TextVi
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我想调出一个用于输入电话号码的键盘。有没有办法在我自己的 Activity 中显示此对话框并捕获用户输入的内容。我需要能够控制用户点击调用时发生的情况。所以我很感兴趣自定义允许用户输入电话号码的 Ac
我希望软键盘位于我的布局之上,而不是在它弹出时四处移动我的布局。我该怎么做呢?我查看了 list ,但从未设置 android:windowSoftInputMode="adjustResize" 此
主题:将某些键替换为另一个键值。 例如如果我按 P,它应该是 F24。 当我尝试从 .ini 文件加载键值时, Hook 不再是全局的。它仅在 winapi 窗体处于焦点时才有效。 我的 DLL 代码
当我点击 EditText 时,是否可以用小写字母启动 android 键盘?基本上,我想要的是将 EditText 中的第一个字母小写,但也让用户可以根据需要将其变为大写...... (EditTe
我想监控 IOS 上的键盘隐藏按钮并触发一个事件。我在说: 我只想在用户按下实际按钮时进行监控。我不想要键盘隐藏时的事件。 最佳答案 用户键盘通知观察者.. 对于 swift NSNotificati
在经历了这一切之后就像认真的...... Easy way to dismiss keyboard? ...我有多个 TextFields 和一些 TextViews。有没有办法对所有文本字段进行批处
所以我想在我的应用程序中添加一个键盘,其中包含表情符号,就像 Whatsapp 或环聊一样。我怎样才能做到这一点?我想保留我的键盘,因为我只想添加标签来放置表情符号。我认为软键盘很容易支持它,但到目前
首先,我会让您知道,我在 StackOverflow 以及 Google 和 Github 上查看了很多很多不同的帖子。我已经到处寻找对我有帮助的任何。但是,似乎没有任何效果。它要么已经过时(超过 1
当按下相应的键时,我试图让我的游戏中的宇宙飞船 (PlayerShip.gif) 向左、向右、向上和向下移动。我知道我需要一个 keyboardListener 但我在弄清楚它的去向以及它是如何实际实
我正在尝试制作一个 HID USB 设备。我搜索了一下,发现键盘的输出有 8 个字节。第一个字节是修饰符,第二个字节是保留字节,其余 6 个字节是关键代码。我认为在某些情况下,例如“prtsc”,需要
我最近开始学习 Vim,在深入学习之前,我有一个问题需要回答。 使用 AZERTY 键盘,我是否应该重新映射命令和快捷方式的键以适应 QWERTY 键盘的键位置? 我之所以问这个,是因为显然在创建这些
我一直认为在使用 Dvorak 布局之前,我需要购买 Dvorak 键盘。但是我在亚马逊上找不到。仅仅是从 Qwerty 键盘上弹出键并移动它们吗? 最佳答案 为了帮助您了解键盘布局,您可以重新排列
我不敢相信我还没有找到任何关于此的文档,但我想知道如何命令键盘激活并接收来自它的输入。我可以找到在编辑文本字段时操作弹出键盘的所有示例。谢谢 最佳答案 您还可以使用 UIKeyInput 协议(pro
我有一个 UITextField,其中弹出的键盘已禁用其 Shift 键。键盘类型设置为 UIKeyboardTypeNamePhonePad,看起来应该允许大写。 如果我将键盘类型更改为“默认”但保
背景:我的表单有一个 TWebBrowser。我想用 ESC 关闭表单,但 TWebBrowser 吃掉了击键 - 所以我决定使用键盘 Hook 。 问题是表单可以同时在多个实例中打开。 无论我做什么
我需要(即客户要求)提供自定义键盘,供用户在文本字段和区域中输入文本。我已经有一些可以执行键盘操作并将测试附加到文本字段的东西,但是我想让它更通用并让它像标准的 iphone 键盘一样工作,即当用户选
我是一名优秀的程序员,十分优秀!