Files
freeCodeCamp/curriculum/challenges/arabic/02-javascript-algorithms-and-data-structures/basic-javascript/using-objects-for-lookups.md
2022-10-20 09:13:17 -07:00

3.2 KiB

id, title, challengeType, videoUrl, forumTopicId, dashedName
id title challengeType videoUrl forumTopicId dashedName
56533eb9ac21ba0edf2244ca استخدام الكائنات للبحث (Using Objects for Lookups) 1 https://scrimba.com/c/cdBk8sM 18373 using-objects-for-lookups

--description--

يمكن اعتبار الكائنات كمخزن بطريقة هُوِيَّة/قيمة، مثل القاموس. إذا كانت لديك بيانات جدولية، فيمكنك استخدام كائن للبحث عن القيم بدلاً من عبارة switch أو تسلسل if/else. هذا مفيد للغاية عندما تعرف أن بيانات الإدخال الخاصة بك محدودة بمدى معين.

وفيما يلي مثال على بحث أبجدي عكسي بسيط:

const alpha = {
  1:"Z",
  2:"Y",
  3:"X",
  4:"W",
  ...
  24:"C",
  25:"B",
  26:"A"
};

const thirdLetter = alpha[2];
const lastLetter = alpha[24];

const value = 2;
const valueLookup = alpha[value];

يكون thirdLetter مقطع Y، ويكون lastLetter مقطع C، ويكون valueLookup مقطع Y.

--instructions--

حوّل تعبير switch إلى كائن يسمى lookup. استخدمه للبحث عن val وتعيين المقطع المرتبط بمتغير result.

--hints--

يجب أن تساوي phoneticLookup("alpha") مقطع Adams

assert(phoneticLookup('alpha') === 'Adams');

يجب أن تساوي phoneticLookup("bravo") مقطع Boston

assert(phoneticLookup('bravo') === 'Boston');

يجب أن تساوي phoneticLookup("charlie") مقطع Chicago

assert(phoneticLookup('charlie') === 'Chicago');

يجب أن تساوي phoneticLookup("delta") مقطع Denver

assert(phoneticLookup('delta') === 'Denver');

يجب أن تساوي phoneticLookup("echo") مقطع Easy

assert(phoneticLookup('echo') === 'Easy');

يجب أن تساوي phoneticLookup("foxtrot") مقطع Frank

assert(phoneticLookup('foxtrot') === 'Frank');

يجب أن تساوي phoneticLookup("") كلمة undefined

assert(typeof phoneticLookup('') === 'undefined');

لا يجب عليك تعديل تعبير return

assert(code.match(/return\sresult;/));

لا يجب عليك استخدام تعبيرات case, أو switch, أو if

assert(
  !/case|switch|if/g.test(code.replace(/([/]{2}.*)|([/][*][^/*]*[*][/])/g, ''))
);

--seed--

--seed-contents--

// Setup
function phoneticLookup(val) {
  let result = "";

  // Only change code below this line
  switch(val) {
    case "alpha":
      result = "Adams";
      break;
    case "bravo":
      result = "Boston";
      break;
    case "charlie":
      result = "Chicago";
      break;
    case "delta":
      result = "Denver";
      break;
    case "echo":
      result = "Easy";
      break;
    case "foxtrot":
      result = "Frank";
  }

  // Only change code above this line
  return result;
}

phoneticLookup("charlie");

--solutions--

function phoneticLookup(val) {
  let result = "";

  const lookup = {
    alpha: "Adams",
    bravo: "Boston",
    charlie: "Chicago",
    delta: "Denver",
    echo: "Easy",
    foxtrot: "Frank"
  };

  result = lookup[val];

  return result;
}