اذهب إلى المحتوى
  • 0

كيفية احضار الخصائص من كائن بشكل متغير في JavaScript

مكيون تقنية المعلومات

السؤال

Recommended Posts

  • 0

هل يمكنك توضيح ما تحاول فعله تماماً،

ويفضل كذلك مشاركة ملفات المشروع

فلم افهم ما هو الـ data في الكود الخاص بك ولا عرف ما هو الـ title  الذي تحاول تغيير.

رابط هذا التعليق
شارك على الشبكات الإجتماعية

  • 0

المقصد هو عند اختيار عن طريق القوائم المنسدلة 

يقوم الفانكشين بعرض البيانات حسب مايتم اختياره من خلال for 

اي عند اختيار على سبيل المثال category يقوم بعرض البيانات حسب category بدل title

والسؤال الدقيق هو كيف اقوم تغيير اسم الخاصية title في data[i].title إلى category مثل data[i].category تلقائي عند اختيار القائمة المنسدلة

    <select onchange="test(this.value)" class="form-select form-select-lg mb-3">
        <option value="" selected>Select</option>
        <option >title</option>
        <option >desc</option>
        <option >category</option>
      </select>

مثال على الداتا

let data = [
    {
    title:'aaaaaaaaaaaa',
    desc:'bbbbbbbbbbbbb',
    category:'ccccccccccc',
    },
    {
    title:'cccccccccccc',
    desc:'dddddddddddddd',
    category:'ccccccccccc',
    },
];

الفانكشن

function test(value)
    {
        for(let i=0; i < data.length; i++){
            console.log(data[i].title);
        }
    }

 

رابط هذا التعليق
شارك على الشبكات الإجتماعية

  • 0
بتاريخ 39 دقائق مضت قال مكيون تقنية المعلومات:

المقصد هو عند اختيار عن طريق القوائم المنسدلة 

يقوم الفانكشين بعرض البيانات حسب مايتم اختياره من خلال for 

اي عند اختيار على سبيل المثال category يقوم بعرض البيانات حسب category بدل title

والسؤال الدقيق هو كيف اقوم تغيير اسم الخاصية title في data[i].title إلى category مثل data[i].category تلقائي عند اختيار القائمة المنسدلة

    <select onchange="test(this.value)" class="form-select form-select-lg mb-3">
        <option value="" selected>Select</option>
        <option >title</option>
        <option >desc</option>
        <option >category</option>
      </select>

مثال على الداتا

let data = [
    {
    title:'aaaaaaaaaaaa',
    desc:'bbbbbbbbbbbbb',
    category:'ccccccccccc',
    },
    {
    title:'cccccccccccc',
    desc:'dddddddddddddd',
    category:'ccccccccccc',
    },
];

الفانكشن

function test(value)
    {
        for(let i=0; i < data.length; i++){
            console.log(data[i].title);
        }
    }

 

اعتقد ان ما تحاول القيام به هو الوصول إلى خصائص الكائن بشكل ديناميكي (object dynamic key)

يمكنك فعل ذلك كالتالي :

let data = [
    {
    title:'aaaaaaaaaaaa',
    desc:'bbbbbbbbbbbbb',
    category:'ccccccccccc',
    },
    {
    title:'cccccccccccc',
    desc:'dddddddddddddd',
    category:'ccccccccccc',
    },
];

function test(value)
{
  for(let i=0; i < data.length; i++){
    const x = data[i];
    console.log(x[value]);
  }
}
test("title"); 
// aaaaaaaaaaaa 
// cccccccccccc

test("desc"); 
// bbbbbbbbbbbbb
// dddddddddddddd

 

رابط هذا التعليق
شارك على الشبكات الإجتماعية

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...