freeCodeCamp/curriculum/challenges/spanish/02-javascript-algorithms-an.../object-oriented-programming/use-an-iife-to-create-a-mod...

63 lines
3.0 KiB
Markdown
Raw Normal View History

2018-10-08 17:34:43 +00:00
---
id: 587d7db2367417b2b2512b8c
title: Use an IIFE to Create a Module
challengeType: 1
2018-10-10 20:20:40 +00:00
videoUrl: ''
localeTitle: Utilice un IIFE para crear un módulo
2018-10-08 17:34:43 +00:00
---
## Description
2018-10-10 20:20:40 +00:00
<section id="description"> Una <code>immediately invoked function expression</code> ( <code>IIFE</code> ) se usa a menudo para agrupar la funcionalidad relacionada en un solo objeto o <code>module</code> . Por ejemplo, un desafío anterior definió dos mixins: <blockquote> función glideMixin (obj) { <br> obj.glide = function () { <br> console.log (&quot;Deslizamiento en el agua&quot;); <br> }; <br> } <br> función flyMixin (obj) { <br> obj.fly = function () { <br> console.log (&quot;Flying, wooosh!&quot;); <br> }; <br> } </blockquote> Podemos agrupar estos <code>mixins</code> en un módulo de la siguiente manera: <blockquote> deja motionModule = (function () { <br> regreso { <br> glideMixin: function (obj) { <br> obj.glide = function () { <br> console.log (&quot;Deslizamiento en el agua&quot;); <br> }; <br> } <br> flyMixin: function (obj) { <br> obj.fly = function () { <br> console.log (&quot;Flying, wooosh!&quot;); <br> }; <br> } <br> } <br> }) (); // Los dos paréntesis provocan que la función se invoque inmediatamente. </blockquote> Tenga en cuenta que tiene una <code>immediately invoked function expression</code> ( <code>IIFE</code> ) que devuelve un objeto <code>motionModule</code> . Este objeto devuelto contiene todos los comportamientos de <code>mixin</code> como propiedades del objeto. La ventaja del patrón del <code>module</code> es que todos los comportamientos de movimiento se pueden empaquetar en un solo objeto que luego pueden ser utilizados por otras partes de su código. Aquí hay un ejemplo usándolo: <blockquote> motionModule.glideMixin (pato); <br> duck.glide (); </blockquote></section>
2018-10-08 17:34:43 +00:00
## Instructions
2018-10-10 20:20:40 +00:00
<section id="instructions"> Cree un <code>module</code> llamado <code>funModule</code> para envolver los dos <code>mixins</code> <code>isCuteMixin</code> y <code>singMixin</code> . <code>funModule</code> debería devolver un objeto. </section>
2018-10-08 17:34:43 +00:00
## Tests
<section id='tests'>
```yml
tests:
- text: <code>funModule</code> debe definirse y devolver un objeto.
testString: 'assert(typeof funModule === "object", "<code>funModule</code> should be defined and return an object.");'
- text: <code>funModule.isCuteMixin</code> debe acceder a una función.
testString: 'assert(typeof funModule.isCuteMixin === "function", "<code>funModule.isCuteMixin</code> should access a function.");'
- text: <code>funModule.singMixin</code> debe acceder a una función.
testString: 'assert(typeof funModule.singMixin === "function", "<code>funModule.singMixin</code> should access a function.");'
```
</section>
## Challenge Seed
<section id='challengeSeed'>
<div id='js-seed'>
```js
let isCuteMixin = function(obj) {
obj.isCute = function() {
return true;
};
};
let singMixin = function(obj) {
obj.sing = function() {
console.log("Singing to an awesome tune");
};
};
2018-10-10 20:20:40 +00:00
2018-10-08 17:34:43 +00:00
```
</div>
</section>
## Solution
<section id='solution'>
```js
2018-10-10 20:20:40 +00:00
// solution required
2018-10-08 17:34:43 +00:00
```
</section>