--- id: 5a24c314108439a4d403616f title: Revisa el uso de "props" con componentes funcionales sin estado challengeType: 6 forumTopicId: 301411 dashedName: review-using-props-with-stateless-functional-components --- # --description-- Excepto por el último desafío, has estado pasando props a componentes funcionales sin estado. Estos componentes actúan como funciones puras. Aceptan props como entrada y devuelven la misma vista cada vez que se les pasa el mismo props. Tal vez te estes preguntando qué es estado, y el próximo desafío lo cubrirá con más detalle. Antes de eso, aquí hay una revisión de la terminología de los componentes. Un *componente funcional sin estado*, es cualquier función que escribas que acepte props y devuelva JSX. Un *componente sin estado*, por otra parte, es una clase que extiende `React.Component`, pero no usa el estado interno (que será cubierto en el siguiente desafío). Finalmente, un *componente con estado* es un componente de clase que mantiene su propio estado interno. Puedes ver componentes con estado referidos simplemente como componentes de React. Un patrón común es intentar minimizar el estado y crear componentes funcionales sin estado siempre que sea posible. Esto ayuda a contener tu administración de estado a un área específica de tu aplicación. A su vez, esto mejora el desarrollo y el mantenimiento de tu aplicación al facilitar el seguimiento de cómo los cambios de estado afectan a su comportamiento. # --instructions-- El editor de código tiene un componente `CampSite` que renderiza un componente `Camper` como un componente hijo. Define el componente `Camper` y asigna los props predeterminados de `{ name: 'CamperBot' }`. Dentro del componente `Camper`, renderiza el código que quieras, pero asegúrate de tener un elemento `p` que incluya sólo el valor `name` que se pasa como un `prop`. Por último, define `propTypes` en el componente `Camper` para requerir que `name` sea proporcionado como un prop y verifique que sea de tipo `string`. # --hints-- El `CampSite` debe renderizarse. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(CampSite)); return mockedComponent.find('CampSite').length === 1; })() ); ``` El componente `Camper` debe renderizarse. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(CampSite)); return mockedComponent.find('Camper').length === 1; })() ); ``` El componente `Camper` debe incluir props predeterminados que asignen la cadena `CamperBot` a la clave `name`. ```js assert( /Camper.defaultProps={name:(['"`])CamperBot\1,?}/.test( __helpers.removeWhiteSpace(code) ) ); ``` El componente `Camper` debe incluir tipos de prop que requieran que el prop `name` sea del tipo `string`. ```js assert( /Camper.propTypes={name:PropTypes.string.isRequired,?}/.test( __helpers.removeWhiteSpace(code) ) ); ``` El componente `Camper` debe contener un elemento `p` que contenga únicamente el texto del prop `name`. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(CampSite)); return ( mockedComponent.find('p').text() === mockedComponent.find('Camper').props().name ); })() ); ``` # --seed-- ## --before-user-code-- ```jsx var PropTypes = { string: { isRequired: true } }; ``` ## --after-user-code-- ```jsx ReactDOM.render(, document.getElementById('root')) ``` ## --seed-contents-- ```jsx class CampSite extends React.Component { constructor(props) { super(props); } render() { return (
); } }; // Change code below this line ``` # --solutions-- ```jsx class CampSite extends React.Component { constructor(props) { super(props); } render() { return (
); } }; // Change code below this line const Camper = (props) => { return (

{props.name}

); }; Camper.propTypes = { name: PropTypes.string.isRequired }; Camper.defaultProps = { name: 'CamperBot' }; ```