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