منتدى فيجوال بيسك لكل العرب | منتدى المبرمجين العرب

نسخة كاملة : إيقاف عمل أداة أثناء الـ Form_Load
أنت حالياً تتصفح نسخة خفيفة من المنتدى . مشاهدة نسخة كاملة مع جميع الأشكال الجمالية .
الصفحات : 1 2
بسم الله الرحمن الرحيم 
أخوتي الكرام 

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

لدي Combobox1

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

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

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

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


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

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

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

و لكم جزيل الشكر
استخدم : 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
ألف شكر أخي 
معلومة جديدة و نجحت تماما 

كل الشكر و االتقدير
أخي الكريم 

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



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

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

عن طريق SelectionChangeCommitted

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

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


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

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



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

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

عن طريق SelectionChangeCommitted

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

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


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







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


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


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

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

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

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

و هذا الكود يعمل في كل الأدوات الأخرى بشكل ناجح
ملاحظة : في الحدث Form1_Load ( لم اعدل شيء ولكن , تعليق فقط ) طريقة جلب البيانات مخبوصة وأنت في غنى عن الكثير من الأكواد.

المشروع بعد التعديل :
[attachment=17426]

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

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


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


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