Usando ES6 com React

Babel não faz parte do React. Na verdade, o propósito de Babel não é sequer o de ser um transpiler JSX. Babel é antes de tudo um compilador de JavaScript. Leva código ES* e o transforma para rodar em navegadores que não suportam código ES*. O Babel usa principalmente código ES6 e ES7 e os transforma em código ES5. Ao fazer essas transformações ECMAScript, é trivial também transformar expressões JSX em chamadas React.createElement(). Isto é o que examinamos na seção anterior.

Dado que Babel é o mecanismo para transformar JSX, ele permite que você escreva código que será executado em futuras versões do ES*. Na página HTML abaixo, o conhecido Componente Mensagem foi reescrito para aproveitar o uso de Classes ES6. Babel não só transforma a sintaxe JSX, mas também está transformando a sintaxe da classe ES6 para a sintaxe ES5, que pode ser analisada pelos mecanismos do navegador ES5.

<!DOCTYPE html>
<html>
    <head>
        <script src="https://fb.me/react-15.2.0.js"></script>
        <script src="https://fb.me/react-dom-15.2.0.js"></script>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.23/browser.min.js"></script>
    </head>
<body>
    <div id="app"></div>
    <script type="text/babel">

        class Mensagem extends React.Component { //notice use of React.Component
            render(){
                return <div>Olá {this.props.name}</div>;
            }
        };

        ReactDOM.render(<Mensagem name="Valter" />, document.getElementById('app'));

        /*** ANTERIORMENTE ***/
        /* var Mensagem = React.createClass({
         *    render: function() {
         *        return <div>Olá {this.props.name}</div>;
         *    }
         * });
         *
         * ReactDOM.render(<Mensagem name="Valter" />, document.getElementById('app'));
         */
    </script>
</body>
</html>

No documento HTML acima, o Babel está pegando esse código:

class Mensagem extends React.Component {
    render(){
        return <div>Olá {this.props.name}</div>;
    }
};

ReactDOM.render(<HelloMessage name="Valter" />, document.getElementById('app'));

E transformando nisso:

"use strict";

var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();

var _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }

function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }

var Mensagem = (function (_React$Component) {
    _inherits(Mensagem, _React$Component);

    function Mensagem() {
        _classCallCheck(this, Mensagem);

        _get(Object.getPrototypeOf(Mensagem.prototype), "constructor", this).apply(this, arguments);
    }

    _createClass(Mensagem, [{
        key: "render",
        value: function render() {
            return React.createElement(
                "div",
                null,
                "Olá ",
                this.props.name
            );
        }
    }]);

    return Mensagem;
})(React.Component);

ReactDOM.render(React.createElement(Mensagem, { name: "Valter" }), document.getElementById('app'));

Usando ES6 & ES* com React

A maioria das Características do ES6 com algumas ressalvas podem ser usadas para escrever JavaScript que é transformado pelo Babel 5.8.23 (i.e., https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.23/browser.js).

Observações

  • Obviamente, uma pessoa ainda pode usar o Babel para o propósito pretendido (isto é, compilar código JavaScript mais novo para código JavaScript mais antigo) sem usar o JSX. No entanto, a maioria das pessoas que usam o React estão aproveitando o Babel para recursos ES* e transformação JSX.

  • Aprenda mais sobre o Babel lendo Babel handbook

results matching ""

    No results matching ""