تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
[سؤال] إيقاف عمل أداة أثناء الـ Form_Load
#1
بسم الله الرحمن الرحيم 
أخوتي الكرام 

لدي مشكلة صغيرة 

لدي Combobox1

في حدث الـ Form_Load أقوم بملئ الـ ComboBox بالبيانات

و في حدث ComboBox1_SelectedIndexChanged ينفذ أمر محدد 

المشكلة أنه عند تحميل الفورم يقوم الـ Combobox بتنفيذ الأمر دون النقر على الخيار المراد طبعا ينفذ الأمر الأول 

و ذلك لأن ملئه بالبيانات في حدث تحميل الفورم هو تغيير على محتوياته ما يؤدي إلى تنفيذ الامر


ما أريده هو منع الـ ComboBox من تنفيذ الأوامر أثناء تحميل الفورم 

التنفيذ فقط من داخل الفورم 

أرجو أن تكون المشكلة واضحة 

و لكم جزيل الشكر
الرد
تم الشكر بواسطة:
#2
استخدم : SelectionChangeCommitted
تحدث فقط عندما يقوم المستخدم بالإجراء

كود :
   Private Sub ComboBox1_SelectionChangeCommitted(sender As Object, e As EventArgs) Handles ComboBox1.SelectionChangeCommitted


   End Sub



بدلاً من : SelectedIndexChanged
تحدث في أي وقت يتم فية تغيير العنصر المحدد
كود :
   Private Sub ComboBox1_SelectedIndexChanged(sender As Object, e As EventArgs) Handles ComboBox1.SelectedIndexChanged

   End Sub
الرد
#3
ألف شكر أخي 
معلومة جديدة و نجحت تماما 

كل الشكر و االتقدير
الرد
تم الشكر بواسطة:
#4
أخي الكريم 

الطريقة تعمل تماما و تمنع تنفيذ الأمر أثناء تحميل الفورم كما تفضلت تماما



لكن المشكلة أنه باستخدام هذه الطريقة لا أحصل عى النتيجة الصحيحة 
فمثلا الـ ComboBox تعرض الأسماء من جدول الطلاب في قاعدة البيانات 

المطلوب عن النقر على اسم الطالب يقوم الكود باستدعاء باقي المعلومات و يضعها في TextBox

عن طريق SelectionChangeCommitted

 النتيجة لا تتطابق مع الاسم الذي نبحث عنه و كل ما اخترت اسم تظهر نتيجة الاسم الذي اخترته قبل

إذا بحثت عن محمد لا يعطي نتيجة ثم أبحث عن أحمد أحصل على نتيجة محمد ثم على اسماعيل فأحصل على نتيجة أحمد و هكذا 


أما عن طريق SelectedIndexChanged 
أحصل على النتائج الدقيقة تماما و بنفس الكود لكن تبقى مشكلة تنفيذ الأمر أثناء تحميل الفورم 
الرد
تم الشكر بواسطة:
#5
أرجو المساعدة
الرد
تم الشكر بواسطة:
#6
(18-03-18, 12:33 AM)AL - WafaaPro كتب :
أخي الكريم 

الطريقة تعمل تماما و تمنع تنفيذ الأمر أثناء تحميل الفورم كما تفضلت تماما



لكن المشكلة أنه باستخدام هذه الطريقة لا أحصل عى النتيجة الصحيحة 
فمثلا الـ ComboBox تعرض الأسماء من جدول الطلاب في قاعدة البيانات 

المطلوب عن النقر على اسم الطالب يقوم الكود باستدعاء باقي المعلومات و يضعها في TextBox

عن طريق SelectionChangeCommitted

 النتيجة لا تتطابق مع الاسم الذي نبحث عنه و كل ما اخترت اسم تظهر نتيجة الاسم الذي اخترته قبل

إذا بحثت عن محمد لا يعطي نتيجة ثم أبحث عن أحمد أحصل على نتيجة محمد ثم على اسماعيل فأحصل على نتيجة أحمد و هكذا 


أما عن طريق SelectedIndexChanged 
أحصل على النتائج الدقيقة تماما و بنفس الكود لكن تبقى مشكلة تنفيذ الأمر أثناء تحميل الفورم 







تأكد من طريقة إستخدامك للأكواد , 


SelectionChangeCommitted  تعمل تماماً مثل SelectedIndexChanged 
الرد
تم الشكر بواسطة:
#7
أخي الكود صحيح تماما 
أستخدمه في Button و في TextBox و كما استخدمه في Combobox
 
و لكن عند وضعه في الحدث SelectionChangeCommitted  
عندها لا يعطيني نتيجة الخيار نفسه كما أنني عند اختيار الخيار ( محمد ) مثلا يظهر في الـ Combobox  الخيار ( أحمد ) و هكذا 


هل من طريقة أخرى لإيقاف تنفيذ كود أو أمر محدد أثناء تحميل الفورم و هذا الكود المراد إيقافه ليس ضمن حدث الفورم لود
الرد
تم الشكر بواسطة:
#8
هل ممكن أن ترفق الكود الذي تستخدمة .

لا يمكن لـ ( SelectionChangeCommitted ) أن تجلب بيانات مختلفة عن المحددة ( الآن ) في الـ ComboBox
الرد
تم الشكر بواسطة:
#9
سأرفع مثال بسيط

مثال عن المشكلة

نتيجة البحث غير متطابقة مع الاختيار من Combobox

و هذا الكود يعمل في كل الأدوات الأخرى بشكل ناجح


الملفات المرفقة
.rar   WindowsApplication1.rar (الحجم : 332.58 ك ب / التحميلات : 19)
الرد
تم الشكر بواسطة:
#10
ملاحظة : في الحدث Form1_Load ( لم اعدل شيء ولكن , تعليق فقط ) طريقة جلب البيانات مخبوصة وأنت في غنى عن الكثير من الأكواد.

المشروع بعد التعديل :

.zip   WindowsApplication1.zip (الحجم : 684.48 ك ب / التحميلات : 25)

لاحظ السطرين رقم : 36 + 37 في الكود

BindingContext في السطر رقم 46 لا تستخدم بهذة الطريقة .
Me.BindingContext(ds, "WItem").Count


من الأفضل سؤال الجدول مباشرتاً :
ds.Tables("WItem").Rows.Count


أو إستخدام Fill للسؤال عن عدد السجلات الراجعة من الإستعلام :
If da.Fill(ds, "WItem") > 0 Then
Fill تعود برقم , وهذا الرقم هو عدد السجلات المتأثرة من تنفيذ الإستعلام 
وهو عدد السجلات من جملة SELECT
الرد
تم الشكر بواسطة:


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  [VB.NET] فتح أداة webbrowser بإستخدام فايرفوكس أو كروم صالح حمادي 5 1,037 12-11-20, 11:57 PM
آخر رد: صالح حمادي
  [سؤال] مشكل مع أداة ReportViewer HUNTER25 0 284 07-10-20, 10:30 PM
آخر رد: HUNTER25
  سؤال بخصوص أداة TabControl MustafaShaker 2 445 20-09-20, 03:21 PM
آخر رد: MustafaShaker
  [VB.NET] الكتابة في أداة تيكس بوكس برمجيا sniperjawadino 6 645 19-09-20, 03:13 AM
آخر رد: sniperjawadino
  إضافة بيانات جدول ثالث أثناء طباعة صفحة التقرير عبد العزيز البسكري 2 732 08-07-20, 03:24 PM
آخر رد: عبد العزيز البسكري
  خطأ أثناء محاولة إضافة الصّور عبد العزيز البسكري 8 783 06-05-20, 02:45 AM
آخر رد: عبد العزيز البسكري
  [VB.NET] إستخدام أداة C# في مشروع VB sniperjawadino 5 746 10-03-20, 04:50 PM
آخر رد: asemshahen5
  سوؤال بخصوص أداة FlowLayoutPanel ابو روضة 16 2,191 07-01-20, 02:32 PM
آخر رد: ابو روضة
  أداة ColorDialog التحكم بموقع الاداة alnasser 0 516 06-01-20, 01:43 AM
آخر رد: alnasser
  خطأ أثناء طباعة جميع محتويات الداتاجرفيو hazim1 0 452 15-12-19, 11:07 PM
آخر رد: hazim1

التنقل السريع :


يقوم بقرائة الموضوع: بالاضافة الى ( 1 ) ضيف كريم