This example shows you how to set keyboard type on TextField
in Flutter.
TextField
has keyboardType
parameter.
TextField( keyboardType: , )
Name:
TextField( decoration: InputDecoration( labelText: 'Name' ), keyboardType: TextInputType.name, )
data:image/s3,"s3://crabby-images/9612e/9612ee5866d5d432b2c65252e10f2c52ff3d95da" alt=""
data:image/s3,"s3://crabby-images/536b5/536b5177a6c6130ef532eda5d1b16a1241350b05" alt=""
Email:
TextField( decoration: InputDecoration( labelText: 'Email' ), keyboardType: TextInputType.emailAddress, )
data:image/s3,"s3://crabby-images/3ff54/3ff5471ab548c4a2a76d3126139f4bbaf2f1f862" alt=""
data:image/s3,"s3://crabby-images/d2694/d269447b14891b72cb6a4dd3122375c646c37de4" alt=""
Phone number:
TextField( decoration: InputDecoration( labelText: 'Phone number' ), keyboardType: TextInputType.phone, )
data:image/s3,"s3://crabby-images/24ca7/24ca7800b5b7235f5fa78f632fcffb2550b02b97" alt=""
data:image/s3,"s3://crabby-images/8639f/8639fd0e2babafd369efeb743d909423f021ae18" alt=""
Datetime:
TextField( decoration: InputDecoration( labelText: 'Datetime' ), keyboardType: TextInputType.datetime, )
data:image/s3,"s3://crabby-images/7fd57/7fd57ed2eec6d607ada28b1f3dee279f98e50e21" alt=""
data:image/s3,"s3://crabby-images/c3da3/c3da30b51e167f5bd9b6f09a451cea6eb8a9b547" alt=""
Full source code:
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); @override Widget build(BuildContext context) { return MaterialApp( title: 'Flutter Demo', theme: ThemeData( primarySwatch: Colors.blue, ), home: const MyHomePage(title: 'Flutter Demo Home Page'), ); } } class MyHomePage extends StatefulWidget { const MyHomePage({super.key, required this.title}); final String title; @override State<MyHomePage> createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text(widget.title), ), body: Center( child: Padding( padding: const EdgeInsets.all(20), child: Column( mainAxisAlignment: MainAxisAlignment.center, children: [ Row( children: const [ Expanded( child: TextField( decoration: InputDecoration(labelText: 'Name'), keyboardType: TextInputType.name, ), ) ], ), Row( children: const [ Expanded( child: TextField( decoration: InputDecoration(labelText: 'Email'), keyboardType: TextInputType.emailAddress, ), ) ], ), Row( children: const [ Expanded( child: TextField( decoration: InputDecoration(labelText: 'Phone number'), keyboardType: TextInputType.phone, ), ) ], ), Row( children: const [ Expanded( child: TextField( decoration: InputDecoration(labelText: 'URL'), keyboardType: TextInputType.url, ), ) ], ), Row( children: const [ Expanded( child: TextField( decoration: InputDecoration(labelText: 'Datetime'), keyboardType: TextInputType.datetime, ), ) ], ), Row( children: const [ Expanded( child: TextField( decoration: InputDecoration(labelText: 'Number'), keyboardType: TextInputType.number, ), ) ], ), ], ), ), ), ); } }