#yyds干货盘点# 歌谣学前端之React中jsx

时间:2022-12-07 11:00:50

前言

我是歌谣 我有个兄弟 巅峰的时候排名c站总榜19 叫前端小歌谣 曾经我花了三年的时间创作了他 现在我要用五年的时间超越他 今天又是接近兄弟的一天人生难免坎坷 大不了从头再来 歌谣的意志是永恒的 放弃很容易 但是坚持一定很酷 微信公众号前端小歌谣

#yyds干货盘点# 歌谣学前端之React中jsx

总结

// 创建一个React元素 我是按钮 // 命令式编程 // const button = React.createElement('button', {}, '我是按钮'); // 声明式编程,结果导向的编程 // 在React中可以通过JSX(JS扩展)来创建React元素,JSX需要被翻译为JS代码,才能被React执行 // 要在React中使用JSX,必须引入babel来完成“翻译”工作 // const button = 我是按钮; // React.createElement('button', {}, '我是按钮'); /* * JSX就是React.createElement()的语法糖 * JSX在执行之前都会被babel转换为js代码 * */

代码案例

<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<title>JSX</title>
<script src="script/react.development.js"></script>
<script src="script/react-dom.development.js"></script>
<!-- 引入babel -->
<script src="script/babel.min.js"></script>
</head>
<body>
<div ></div>

<!--设置js代码被babel处理-->
<script type="text/babel">

// 创建一个React元素 <button>我是按钮</button>
// 命令式编程
// const button = React.createElement('button', {}, '我是按钮');

// 声明式编程,结果导向的编程
// 在React中可以通过JSX(JS扩展)来创建React元素,JSX需要被翻译为JS代码,才能被React执行
// 要在React中使用JSX,必须引入babel来完成“翻译”工作
// const button = <button>我是按钮</button>; // React.createElement('button', {}, '我是按钮');

/*
* JSX就是React.createElement()的语法糖
* JSX在执行之前都会被babel转换为js代码
* */
const div = <div>
我是一个div
<button>我是按钮</button>
</div>;

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(div);

</script>
</body>
</html>