React:从来如此便对么
JSX
描述UI
的React
。甚至部分场景下使用Vue
时也会选择JSX
而不是模版语法
。模版语法
才是更自然的选择。接下来让我们看看React
选择JSX
背后的逻辑是什么?这是React
如今生态繁荣的关键因素么?模版语言简史
MVC
框架的V
(view,即视图层)存在的,操作view
的主流方法是模版语法
。PHP
是最好的语言,但在早期PHP
更多是作为HTML
模版语言出现的,这也能从他的全称Hypertext Preprocessor
(超文本预处理器)中窥探出一丝端倪。PHP
代码,将填充了变量值的HTML
会作为数据返回。name
会被填充为变量值:<h1>
<?php echo "My name is {$name}"; ?>
</h1>
PHP
风格的模版语法,比如:基于 Java
的JSP
基于 PHP
二次封装的smarty
基于 Ecmascript
的EJS
PHP
代码)会不可避免的和UI
(HTML
)混杂在一起。UI
,Github
的联合创始人Chris Wanstrath
开发了Mustache
。UI
而轻逻辑的模版解析引擎,主流编程语言几乎都有各自的Mustache
实现。Mustache
语法为:<h1>
My name is {{name}}
</h1>
Mustache
能直观的表达UI
,但是缺失对逻辑的表达能力。更多模版语法
则尝试在UI
与逻辑之间寻找平衡。Django
的DTL
(Django Template Language)除了使用与Mustache
相同的 {{}}
语法表达UI
中的变量,还包含大量的常见逻辑,比如:if else
等流程控制逻辑{% if condition %}
... display
{% endif %}
for in
迭代逻辑<ul>
{% for user in userList %}
<li>{{ user.name }}</li>
{% endfor %}
</ul>
/* 将name转化为小写形式 */
<p>{{ name | lower }}</p>
模版语法
中可以看到很多服务端曾使用的模版语法
的影子。Vue
模版语法时想必会很亲切:<h1>my name is {{name | lower}}</h1>
view
层分离并逐渐发展的前端框架,最符合直觉的方式就是采用模版语法
描述视图,比如09年出现的现象级前端框架angular
。React
并不这么认为。用逆向思维思考
UI
与逻辑。模版语言
的底层逻辑是:即然前端使用HTML
描述UI
,那么我们就扩展HTML
语法,让他能描述逻辑。UI
出发,扩展UI
,描述逻辑。JS
。JS
)出发,扩展逻辑,让他能描述UI
,不就达到同样的效果吗?JSX
—— 一种JS
语法糖。后记
JSX
以逻辑为起点,所以能轻松描述复杂的UI
变化。这使得React
社区的早期参与者可以快速实现各种复杂的基础库,丰富社区生态。React
长期霸榜工程师最愿意使用的前端框架。JSX
那一刻就埋下了伏笔。评论