Files
freeCodeCamp/curriculum/challenges/english/14-responsive-web-design-22/learn-html-by-building-a-cat-photo-app/5dfa30b9eacea3f48c6300ad.md
2024-10-21 07:57:40 -07:00

2.7 KiB

id, title, challengeType, dashedName
id title challengeType dashedName
5dfa30b9eacea3f48c6300ad Step 17 0 step-17

--description--

In previous steps you used an anchor element to turn text into a link. Other types of content can also be turned into a link by wrapping it in anchor tags.

Here is an example of turning an image into a link:

<a href="example-link">
  <img src="image-link.jpg" alt="A photo of a cat.">
</a>

Turn the image into a link by surrounding it with necessary element tags. Use https://freecatphotoapp.com as the anchor's href attribute value.

--hints--

You should have an img element with a src value of https://cdn.freecodecamp.org/curriculum/cat-photo-app/relaxing-cat.jpg. You may have accidentally deleted it.

assert(
  document.querySelector('img') &&
    document.querySelector('img').getAttribute('src') ===
      'https://cdn.freecodecamp.org/curriculum/cat-photo-app/relaxing-cat.jpg'
);

Your anchor (a) element should have an opening tag. Opening tags have this syntax: <elementName>.

assert(document.querySelectorAll('a').length >= 2);

You are missing a closing (a) tag after the image.

assert.lengthOf(document.querySelectorAll('a'), 3);

Your anchor (a) element should have a closing tag. Closing tags have a / just after the < character.

assert(code.match(/<\/a>/g).length >= 2);

You should only add one closing anchor (a) tag. Please remove any extras.

assert.lengthOf(code.match(/<\/a>/g), 3);

Your anchor (a) element does not have an href attribute. Check that there is a space after the opening tag's name and/or there are spaces before all attribute names.

assert(document.querySelector('a').hasAttribute('href'));

Your anchor (a) element should link to https://freecatphotoapp.com. You have either omitted the URL or have a typo.

assert(
  document.querySelectorAll('a')[1].getAttribute('href') ===
    'https://freecatphotoapp.com'
);

Your img element should be nested within the anchor (a) element. The entire img element should be inside the opening and closing tags of the anchor (a) element.

assert(document.querySelector('img').parentNode.nodeName === 'A');

--seed--

--seed-contents--

<html>
  <body>
    <main>
      <h1>CatPhotoApp</h1>
      <h2>Cat Photos</h2>
      <p>Everyone loves <a href="https://cdn.freecodecamp.org/curriculum/cat-photo-app/running-cats.jpg">cute cats</a> online!</p>
      <p>See more <a target="_blank" href="https://freecatphotoapp.com">cat photos</a> in our gallery.</p>
--fcc-editable-region--
      <img src="https://cdn.freecodecamp.org/curriculum/cat-photo-app/relaxing-cat.jpg" alt="A cute orange cat lying on its back.">
--fcc-editable-region--
    </main>
  </body>
</html>