By using this site, you agree to the Privacy Policy and Terms of Use.
موافق
عرب فلاترعرب فلاتر
  • Dart
  • Widgets
  • Packages
  • Tutorials
  • Flutter Roadmap
  • تثبيت Dart
  • تثبيت Flutter
قراءة: شرح استخدام ويدجت TextFormField في فلاتر
شارك
تسجيل الدخول
إشعار أظهر المزيد
Aa
عرب فلاترعرب فلاتر
Aa
  • Dart
  • Widgets
  • Packages
  • Tutorials
  • Flutter Roadmap
  • تثبيت Dart
  • تثبيت Flutter
Search

أقسام الموقع

استكشف جميع أقسام الموقع
قسم Dart في موقع عرب فلاتر

Dart

59 مقالات
قسم Widgets في موقع عرب فلاتر

Widgets

104 مقالات
قسم Packages في موقع عرب فلاتر

Packages

19 مقالات
قسم Tutorials في موقع عرب فلاتر

Tutorials

22 مقالات

أخر المواضيع

استكشف أخر المواضيع المنشورة
شرح الـ Event Loop في Flutter وجعل التطبيق لا يتوقف أبدًا
Tutorials

شرح الـ Event Loop في Flutter وجعل التطبيق لا يتوقف أبدًا

5
حل مشكلة التوافق بين Java و Kotlin و Gradle في فلاتر
Tutorials

حل مشكلة التوافق بين Java و Kotlin و Gradle في فلاتر

10
أفضل الـ Packages في Flutter لتسريع تطوير التطبيقات
Tutorials

أفضل الـ Packages في Flutter لتسريع تطوير التطبيقات

17
لديك حساب موجود؟ تسجيل الدخول
  • Dart
  • Widgets
  • Packages
  • Tutorials
  • Flutter Roadmap
  • تثبيت Dart
  • تثبيت Flutter
© جميع الحقوق محفوظة موقع عرب فلاتر 2023
عرب فلاتر > Widgets > شرح استخدام ويدجت TextFormField في فلاتر
Widgets

شرح استخدام ويدجت TextFormField في فلاتر

عبدالله يوسف
أخر تحديث 2024/11/15
بواسطة عبدالله يوسف اضف تعليق 5 دقيقة للقراءة 4254 مشاهدات 4
شارك
شرح استخدام ويدجت TextFormField في فلاتر
شرح استخدام ويدجت TextFormField في فلاتر
شارك

خدماتنا البرمجية – عرب فلاتر🚀

خدماتنا البرمجية – عرب فلاتر

تعتبر حقول الإدخال Input Fields من العناصر الأساسية في تطبيقات Flutter، وتستخدم لإدخال البيانات والمعلومات من المستخدمين. ومن بين أنواع حقول الإدخال في Flutter، يعد TextFormField الأكثر استخدامًا والأكثر تخصيصًا.

المحتويات
ما هو TextFormField في فلاتر؟الخصائص الأساسية لـ TextFormFieldinitialValuekeyboardTypeobscureTexttextAlignالتحكم في الإدخال والاستجابة للأحداثonChangedonEditingCompleteonFieldSubmittedخصائص التحقق من الصحة والتحقق من الصيغةvalidatorinputFormattersتخصيص النمط والمظهرdecorationstyleمثال على استخدام TextFormField في فلاتر

ما هو TextFormField في فلاتر؟

TextFormField هو عبارة عن ويدجت في Flutter يسمح للمستخدمين بإدخال البيانات النصية، مثل الأسماء والعناوين والرسائل البريدية وكلمات المرور. يحتوي TextFormField على العديد من الخصائص التي يمكن استخدامها لتخصيص المظهر والسلوك لتلبية متطلبات تطبيقك.

“اقرأ أيضاً: شرح استخدام ويدجت IntrinsicHeight في فلاتر“


الخصائص الأساسية لـ TextFormField

يمكن استخدام TextFormField في Flutter للعديد من الأغراض، سواء كان ذلك لجمع الإدخالات النصية أو الرقمية أو البريد الإلكتروني أو المواقع الإلكترونية أو أي نوع آخر من الإدخالات. في هذا الجزء، سنلقي نظرة على الخصائص الأساسية لـ TextFormField:

initialValue

هذه الخاصية تسمح لك بتحديد القيمة الأولية لحقل الإدخال.

TextEditingController _controller = TextEditingController();
TextFormField(
  controller: _controller,
  initialValue: 'Initial value',
)

keyboardType

تسمح هذه الخاصية لك بتحديد نوع لوحة المفاتيح المستخدمة لحقل الإدخال.

TextFormField(
  keyboardType: TextInputType.emailAddress,
)

obscureText

تسمح هذه الخاصية لك بإخفاء النص المدخل في حقل الإدخال، مفيدة لإدخال كلمات المرور.

TextFormField(
  obscureText: true,
)

“اقرأ أيضاً: شرح استخدام AnimatedPositioned في فلاتر“

textAlign

تسمح هذه الخاصية لك بتحديد موضع النص داخل حقل الإدخال.

TextFormField(
  textAlign: TextAlign.center,
)

التحكم في الإدخال والاستجابة للأحداث

يمكن التحكم في الإدخال واستجابة الحقل للأحداث باستخدام الخصائص التالية:

onChanged

يتم استدعاء هذه الدالة عندما يتم تغيير القيمة في حقل الإدخال.

TextFormField(
  onChanged: (value) {
    // Do something with the value
  },
)

onEditingComplete

يتم استدعاء هذه الدالة عندما يتم الانتهاء من تحرير حقل الإدخال.

TextFormField(
  onEditingComplete: () {
    // Do something when editing is complete
  },
)

onFieldSubmitted

يتم استدعاء هذه الدالة عندما يتم تقديم حقل الإدخال بعد الضغط على زر “Enter” على لوحة المفاتيح.

TextFormField(
  onFieldSubmitted: (value) {
    // Do something with thevalue when submitted
  },
)

خصائص التحقق من الصحة والتحقق من الصيغة

يمكن استخدام الخصائص التالية للتحقق من صحة الإدخال وضمان أنه يتوافق مع الصيغة المطلوبة:

validator

يتم استدعاء هذه الدالة عندما تحاول التحقق من صحة الإدخال. يجب على الدالة إرجاع رسالة خطأ إذا لم يتم تلبية متطلبات الصيغة المطلوبة.

TextFormField(
  validator: (value) {
    if (value.isEmpty) {
      return 'Please enter a value';
    }
    return null;
  },
)

inputFormatters

تسمح هذه الخاصية لك بتحديد الصيغة التي يجب أن يتوافق معها الإدخال. يمكن استخدامها لتطبيق القيود على الأحرف المسموح بها أو الأرقام أو الرموز.

TextFormField(
  inputFormatters: [
    FilteringTextInputFormatter.digitsOnly,
  ],
)

تخصيص النمط والمظهر

يمكن تخصيص المظهر والنمط باستخدام الخصائص التالية:

decoration

تسمح هذه الخاصية لك بتحديد الديكور والمظهر الخاص بحقل الإدخال.

TextFormField(
  decoration: InputDecoration(
    labelText: 'Enter your name',
    border: OutlineInputBorder(),
  ),
)

style

تسمح هذه الخاصية لك بتحديد نمط النص داخل حقل الإدخال.

TextFormField(
  style: TextStyle(
    fontSize: 16,
    color: Colors.black,
  ),
)

مثال على استخدام TextFormField في فلاتر

يمكن استخدام TextFormField في فلاتر لإنشاء حقل إدخال نصي للمستخدم. يمكن استخدام هذا الحقل لجمع البيانات من المستخدم واستخدامها في التطبيق حسب الحاجة.

هنا مثال يستخدم TextFormField في فلاتر:

import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      title: 'Text Form Field Example',
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  final GlobalKey<FormState> _formKey = GlobalKey<FormState>();
  late String _name;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Text Form Field Example'),
      ),
      body: Form(
        key: _formKey,
        child: Column(
          children: <Widget>[
            TextFormField(
              decoration: const InputDecoration(
                labelText: 'Enter your name',
              ),
              validator: (value) {
                if (value!.trim().isEmpty) {
                  return 'Please enter your name.';
                }
                return null;
              },
              onSaved: (value) {
                _name = value!;
              },
            ),
            ElevatedButton(
              child: const Text('Submit'),
              onPressed: () {
                if (_formKey.currentState!.validate()) {
                  _formKey.currentState!.save();
                  print('Name: $_name');
                }
              },
            ),
          ],
        ),
      ),
    );
  }
}
مثال على استخدام TextFormField في فلاتر
شرح استخدام ويدجت TextFormField في فلاتر 9

في هذا المثال، تم استخدام TextFormField لجمع اسم المستخدم. يتم تحديد decoration لتزيين حقل الإدخال وتم تحديد validator للتحقق من صحة الإدخال. إذا كان الإدخال فارغًا، فسيتم إرجاع رسالة خطأ. عند الضغط على الزر “Submit”، سيتم التحقق من الإدخال وحفظه في المتغير _name، ثم سيتم طباعة الاسم في وحدة تحكم الإخراج Console.

“اقرأ أيضاً: شرح استخدام ويدجت Visibility في فلاتر“


في هذه المقالة، شرحنا TextFormField في Flutter والخصائص المختلفة التي يمكن استخدامها لتخصيص المظهر والسلوك لتلبية متطلبات تطبيقك. يمكنك استخدام هذه الخصائص لإنشاء حقول إدخال مثالية لتطبيقات Flutter الخاصة بك.

Arab Flutter Community 🚀

انضم إلى مجتمع Arab Flutter
شارك هذا المقال
فيسبوك تويتر Whatsapp Whatsapp لينكد ان تلغرام نسخ الرابط
Avatar of عبدالله يوسف
بواسطة عبدالله يوسف Founder and CEO at ArabFlutter
تابع:
أنا عبدالله يوسف، مهندس مصري ومؤسس موقع عرب فلاتر، ملهم بشغف التكنولوجيا والإبداع. كمصمم مواقع ومبرمج تطبيقات موبايل باستخدام Flutter، أستمتع بخلق عوالم رقمية فريدة ومبتكرة. تتجلى مواهبي في تصميم وتطوير واجهات مستخدم تفاعلية، حيث يمزج الجانب الجمالي بالدقة الهندسية. ما يميزني هو إلمامي الواسع بتقنيات البرمجة والتصميم، ومقدرتي على تطوير تطبيقات متنوعة عبر منصات مختلفة. أعتبر نفسي مبدعًا وملتزمًا، حيث أسعى دائمًا لتحقيق تحسين مستمر في مهاراتي وتقنياتي. أستمتع بتحديات العمل الجماعي وأؤمن بأهمية الابتكار والتطور. بفضل إبداعي والتزامي، أسعى لتقديم حلول فعّالة تلبي توقعات العملاء وتفوق عن المألوف.
اترك تعليقا اترك تعليقا

اترك تعليقاً إلغاء الرد

لن يتم نشر عنوان بريدك الإلكتروني. الحقول الإلزامية مشار إليها بـ *

شرح الـ Event Loop في Flutter وجعل التطبيق لا يتوقف أبدًا
شرح الـ Event Loop في Flutter وجعل التطبيق لا يتوقف أبدًا
Tutorials
حل مشكلة التوافق بين Java و Kotlin و Gradle في فلاتر
حل مشكلة التوافق بين Java و Kotlin و Gradle في فلاتر
Tutorials
أفضل الـ Packages في Flutter لتسريع تطوير التطبيقات
أفضل الـ Packages في Flutter لتسريع تطوير التطبيقات
Tutorials
طريقة انشاء المجلدات باستخدام Dart
طريقة انشاء المجلدات باستخدام كود Dart تلقائيًا
Tutorials

مقالات ذات الصلة

اطلع على المزيد من المقالات المتعلقة بهذا الموضوع!
شرح استخدام ThemeData في فلاتر
Widgets

شرح استخدام ThemeData في فلاتر

37 2
شرح استخدام ويدجت SingleChildScrollView في فلاتر
Widgets

شرح استخدام SingleChildScrollView في فلاتر

26 1
شرح استخدام ويدجت WillPopScope في فلاتر
Widgets

شرح استخدام ويدجت WillPopScope في فلاتر

19 1
شرح استخدام ويدجت RichText في فلاتر 
Widgets

شرح استخدام ويدجت RichText في فلاتر 

20
شرح استخدام ويدجت TextButton في فلاتر
Widgets

شرح استخدام ويدجت TextButton في فلاتر

20
شرح استخدام ويدجت OutlinedButton في فلاتر
Widgets

شرح استخدام ويدجت OutlinedButton في فلاتر

28 1
أظهر المزيد
شعار موقع عرب فلاتر شعار موقع عرب فلاتر

About US

Quick Links

  • خدماتنا
  • من نحن
  • اتصل بنا
  • اتفاقية استخدام
  • سياسة الخصوصية
© جميع الحقوق محفوظة موقع عرب فلاتر 2023
  • Dart
  • Widgets
  • Packages
  • Tutorials
  • Flutter Roadmap
  • تثبيت Dart
  • تثبيت Flutter
adbanner
تم اكتشاف مانع إعلانات
مرحبًا، يرجى إيقاف مانع الإعلانات. الإعلانات تُساهم في دعم موقعنا وتغطية جزء من تكاليف الاستضافة وتطوير المحتوى. شكرًا لتفهمك ودعمك.
Okay, I'll Whitelist
Welcome Back!

Sign in to your account

هل نسيت كلمة المرور؟