今天给各位分享jsx是谁发明的的知识,其中也会对js诞生于哪一年进行解释,如果未能解决您的问答,可在评论区留言!
文章目录:
- 1、怎么在html5中直接编译jsx
- 2、Vue - 渲染函数render
- 3、在2016年学javascript是一种怎样的体验
- 4、为什么我推荐使用JSX开发Vue3
- 5、不依赖 Gulp,Babel,WebPack,还能优雅地写代码吗
怎么在html5中直接编译jsx
/newscodejs.asp?lm2=84list=5icon=/指宽img/fk.giftj=0font=9hot=0new=0line=0lmname=0open=1n=36more=0t=0week=0zzly=0hit=0pls=0
这个文件显示的结果必须是js格式
如输出img src="1.jpg" /唯棚亮
需要写成
document.write("img src=\"1.jpg\" /和猜")
Vue - 渲染函数render
简单的说,在vue中我们使用模板HTML语法来组建页面的,使用render函数我们可以用js语言来构建DOM。因为vue是虚拟DOM,所以在拿到template模板时也要转译成VNode的函数,而用render函数构建DOM,vue就免去了转译的过程。
当使用render函数描述虚拟DOM时,vue提供一个函数,这个函数是就构建虚拟DOM所需要的工具埋橘销。官网上给他起了个名字叫createElement。还有约定它的简写叫h
示例: 分别使用html语法和render函数来实现根据传入的 level (h1-h6)页面渲染不同的标题格式
【1】使用组件的形式
【2】使用render函数的形式(修改child1子组件)
render 函数即渲染函数,它是个函数,render 函数的返回值是VNode(即:虚拟节点,也就是我们要渲染的节点)
createElement 是 render 函数的参数,它本身也是个函数,并且有三个参数。接来下我们重点介绍这三个参数
【弯游1】createElement 第一个参数是必填的,可以是String | Object | Function
示例:
【2】createElement 第二个参数是选填的,一个与模板中属性对应的数据对象 ****常用的有class | style | attrs | domProps | on
【3】createElement 第三个参数是选填的,代表子级虚拟节点 (VNodes),由 createElement() 构建而成,正常来讲接收的是一个字符串或者一个数组,一般数组用的是比较多的
在render函数中,没有提供v-model的实现,所以你必须自己实现相伍陆应的逻辑。这就是深入底层的代价,但与v-model相比,这可以让你更好地控制交互细节。
结果如下:
对于.passive,.capture, .once 这些事件修饰符, Vue 提供了相应的前缀可以用于 on
JSX就是Javascript和XML结合的一种格式。React发明了JSX,利用HTML语法来创建虚拟DOM。当遇到,JSX就当HTML解析,遇到{就当JavaScript解析。
复杂的render函数书写异常痛苦,这就是为什么会有一个Babel插件,用于在 Vue 中使用 JSX 语法,它可以让我们回到更接近于模板的语法上。
JSX语法学习文档: vuejs/JSX JSX语法简介
在2016年学javascript是一种怎样的体验
H5edu教育一直秉承“专注、专业、专心”的理念,实行零基础零学费入学,先就业后交费,是中国移动互联培训行业里的佼佼者,全力打造移动岩锋互联网研肢槐发人才服务优质平台,同时也是国内首家推出html5开发(CSS+Javascript)粗饥晌动画代码教学的实训机构。
为什么我推荐使用JSX开发Vue3
以防万一有的同学实在不看官方文档,我先提一嘴,SFC 就是写 Vue 组件的岩备时候写的.vue文件,这一个文件就是一个 SFC,全称 Single File Component,也即单文件组件。
在开始说我个人的观点之前,我们先来看几个事实:
一是: Vue3 的定义原生支持 JSX,并且 Vue3 源码中有jsx.d.ts来便于使用 JSX。 不知道同学们看到这里会想到什么, 我的第一反应是: 社区对于 JSX 的需求声音是不小的,所以会反向推动 Vue3 官方对于 JSX 的支持。
二是:AntDesign 的 vue3 版本,基本全部都是用 JSX 开发的,而且 Vue3 现在官方的 babel-jsx 插件就是阿里的人一开始维瞎枣迟护的, 虽然我向来不喜欢阿里系的 KPI 推动技术方式,而且现在的 JSX 语法支持也不是很符合我的期望,但至少在使用 JSX 开发是更优秀的选择这点上,我还是很认可 AntDesign 团队的。
OK,说这些呢,主要是先摆出一些事实作为依据,让有些同学可以不需要拿什么:
这些观点来批斗我,首先我都会从客观的角度来分析为什么,至少是我是能讲出优劣势的理由的。
OK,前言差不多到这里,接下来咱给您分析分析,为什么你应该选择 JSX 来开发 Vue。
其实第一点就已经是杀手了,对于想要使用 TypeScript 来开发 Vue3 应用的同学来说,这简直就是 SFC 无法克服的世界难题。
一句话概括: TypeScript 原生支持 JSX 语法,而基本无望 TS 官方能支持 SFC 的 template 语法 。
TS 毫无疑问在前端社区的重要性越来越大,但凡未来对于代码质量有一定要求的前端团队,都应该会选择使用 TS 来进行开发。 而且现在基本上在 NPM 上都能看到包你都能找到对应的 TS 定义,现在使用 TS 开发成本已经只剩下 你是不是会 TS 语法了 ,在这种情况下是否支持 TS 则是开发模式在未来走不走的远的重要原因。
目前 SFC 只能通过shim让 TS 可以引入.vue文件,但是对于所有 SFC 的组件的定义都是一样的:
也就是说你引入的 SFC 组件,TS 是不知道这个组件的 Props 应该接收什么的。所以你无法享受到这些 TS 的优势:
当然你会说既然 Vue 官方能开发处 SFC 的语法,自然会支持这些特性。我表示这当然有可能,但是这个难度是非常大的,需要很多方面的支持,甚至可能需要 TS 官方团队愿意协助, 但是我想不到 TS 官方有什么理由来支持 SFC,因为这只是 Vue 自己创建的方言,在其他场景下是没有使用的,TS 是面向全社区的,我觉得他们不会考虑主动来支持 SFC。
那么有同学要问了,JSX 不也是非原生的 JS 语法么,他怎么就能让 TS 官方支持了呢,是不是 FB 和微硬之间有什么 PY 交易?
这就涉及第二点了,JSX 和静态模板的灵活性区别。
很多人弄错了一个问题,就是觉得 SFC 的模板语法和 JSX 是一样的,都是一种别人发明的语法,并不是 JS 原生的。这是事实,但又有一些区别,这个区别主要是体现在对于 JSX 的认知上。
一句话概括: JSX 并没有扩展 JS 的语法,他只是缩略了 JS 的写法!其本质就是 JS 的语法糖
就像 es6 给增加的语法糖,比如
这种写法并没有扩展 JS 的能力,只是简便了写法,JSX 也是一样的磨李。
JSX 其实就是方法调用,他和 JS 是有一对一对应关系的,我们来看一个例子:
这里的 JSX 语法编译之后其实就是:
而 JSX 就是这些了,没有什么更多的内容,所以说 JSX 只是 方便我们写嵌套的函数调用的语法糖 ,而其本身没有扩展任何其他的内容。
但是 SFC 就不一样了。
SFC 定义的不仅是语法,更是文件。
SFC 的具体定义是 单文件组件 ,它本身就是把一个文件看作一个单位,所以他的约束性是要大很多的,你必须具有固定的文件结构才能使用 SFC,这做了很多的限制:
我们一点点来讲
这个说实话非常非常不方便,很多时候我们写一个页面的时候其实经常会需要把一些小的节点片段拆分到小组件里面进行复用(如果你现在没有这个习惯可能就是因为 SFC 的限制让你习惯了全部写在一个文件内)。
React 生态中丰富的 css-in-js 方案就是很好的例子,我们可以通过:
如果我们这个页面需要使用特定样式的按钮,通过这种方式在页面文件里面封装一下是非常常见的。因为没必要把这个组件拆分出去,他也不是一个可复用的组件,拆分出去了还要多一次import。
Vue 生态基本没有 css-in-js 的成熟方案其实跟这个限制也很有关系。
再来一个例子,比如我们封装了一个 Input 组件,我们希望同时导出 Password 组件和 Textarea 组件来方便用户根据实际需求使用,而这两个组件本身内部就是用的 Input 组件,只是定制了一些 props:
在 JSX 中可以非常简单地实现,但是如果通过 SFC,你可能就要强行拆成三个文件,另外为了方便,你可能还要增加一个index.js来导出这三个组件,你能想象这多了多少工作量么。
我不知道有多少同学看过 Vue 的 template 编译出来之后的代码,以我的经验来说看过的可能不会超过 50%(乐观估计),建议同学们如果还不了解的,可以去尝试看一下。
为什么要看这个呢?因为你看了之后你会发现,你在 template 里面写的类似 HTMl 的内容,其实跟 HTML 根本没啥关系,他们也会被编译成类似 JSX 编译出来的结果。
类似这样的结果,而这里面h函数调用的结果就是一个 VNode,是 Vue 中的节点的基础单元。那么既然这些单元就是一个对象,其实理所当然的,他们是可以作为参数传递的。 也就是说,理论上他们是可以通过props把节点当作参数传递给其他组件的。
这个做法在 React 中非常常见,叫做renderProps,并且其非常灵活:
但是因为 SFC 模板的限制,我们很难在 SFC 里面的 props 上写节点:
这样写是不行的,因为 SFC 定义了:header绑定接受的只能是 js 表达式,而 显然不是。
因为通过 props 传递不行,所以 Vue 才发明了 slot 插槽的概念
虽然我们一直再说 Vue 简单,但是事实上ScopedSlots一度成为新手理解 Vue 的噩梦,很多同学都被这个绕来绕去的作用域整的死去活来。
我们看一个ScopedSlots的例子:
这里ctx是Comp里面的属性,通过这种方式传递出来,让我们在当前组件可以调用父组件里面的属性。这简直就是理解的噩梦,但是如果用 JSX 实现类似功能就非常简单:
我们只是给一个叫做scope的 props 传递来一个函数,这个函数接受一个name属性,在Comp里面会调用这个函数并传入name。 简单来说我们传入的就是一个构建节点片段的函数,就是这么简单。
这就是因为 SFC 的模板的限制,导致灵活性不足,Vue 需要去创造概念,创造关键字来抹平这些能力的不足,而创造的概念自然就引入了学习成本。
所以其实我一直不认可 Vue 比 React 好学的说法的,如果你真的认真研究所有用法,并且总是尝试用最合理的方式实现功能,那么 Vue 绝对不会比 React 简单。
这个体现在两个方面,一个是我们定义在全局的一些固定数据如果要在组件内使用的话,就要通过this挂载到组件上。
比如我们缓存了一份城市数据,这种数据基本上是不会改的,所以也没必要挂载到组件上让其能够响应式。但是在 SFC 里面这是做不到的, 因为模板的执行上下文是在编译时绑定。你在模板里面访问的变量,都会在编译时自动绑定到this上,因为模板需要编译,其本身也是字符串不具有作用域的概念。
而这在 JSX 中则不复存在:
另外一个方面则是在组件使用上,在 SFC 中,组件必须事先注册,因为我们在模板里面写的只能是字符串而不能是具体某个组件变量。 那么模板中的组件和真实的组件对象只能通过字符串匹配来实现绑定。这带来了以下问题:
在 JSX 中则没有这些问题,因为 JSX 里面直接使用组件引用作为参数:
其实上面能看出来,除了 SFC 本身的问题之外,Vue 使用字符串模板也会带来很多的灵活性问题。 最直接的证据,就是 Vue 使用了directive来扩展功能(当然这不是 Vue 发明的,老早的模板引擎就有类似问题)。
为什么说directive是不得已的选择呢?因为静态模板缺失逻辑处理的能力。我们拿列表循环举例,在 JS 中我们可以非常方便地通过map函数来创建列表:
而因为 JSX 本身就是函数调用,所以上面的代码和 JSX 结合起来也非常自然:
上面的例子对应到 JS 如下:
这仍然是因为 JSX 只是 JS 的语法糖的原因,所有能在 JS 中实现的在 JSX 里面都能实现。
而 SFC 的模板是基于字符串编译的,其本身就是一段字符串,我们不能直接在模板里面写map来循环节点,(当然我们可以在可以接收表达式的地方写,比如v-on里面)。
那么我们不能循环节点,有需要这样的功能来渲染列表,怎么办呢?就是发明一个标志来告诉编译器这里需要循环,在 Vue 中的体现就是v-for指令。
同学们可能要问了,既然 Vue 能实现v-for,为什么不直接实现表达式循环列表呢?他当然也可以实现,但是他肯定不会这么选,因为成本太高了。 他要这么做就相当于他要实现一个 JS 引擎,而其实里面很多内容又是不必须的,一个v-for其实就能够适用大部分情况了。
但有了v-for就需要v-if,那么后面还会需要其他各种能力,这就是一种方言的产生和发展的过程。
当然指令也不仅仅是 JS 表达式的代替品,其本身也是增加了一些其他能力的,比如它能够让我们更方便地访问 DOM 节点, 但是嘛,我们用框架的理由不就是为了能够尽可能的屏蔽 DOM 操作嘛
以上就是我对应该选择使用 JSX 还是 SFC 进行开发的分析,其实归根到底 SFC 的问题在于其没有拥抱 JS, 他的语法是自己发明的,他需要有一个 JS 实现的 compiler 来让其最终能在 JS 环境中运行,这本质上就是一种发明, 我们不能否认发明确实有优点,但我们也不能只看有点不看问题,没能拥抱 JS 自然就很难完全复用 JS 社区的优势 而 JS 社区一直在蓬勃发展,好用的工具一直在涌现, 而 SFC 想要使用 JS 社区的这些工具还要自己再实现一份 ,我们可以细数以下 SFC 做了哪些兼容
基本上常用的工具我们都需要等待 Vue 社区或者官方开发了插件之后才能运行。而 JSX 因为有 babel 和 typescript 的官方支持, 基本上所有新的 JS 生态工具原生都是支持的。
在这 Vue3 开始预备发力的阶段,我们还是希望 Vue 社区能够使用更优秀更规范的方式来进行开发, 其实如果我们直接使用 JSX 开发 Vue3,我们会发现很多时候我们都不需要用到emit、attrs这些概念, 甚至如果 Vue3 的 JSX 插件支持,我们甚至能够抛弃slots。
但是因为 Vue3 一定要考虑兼容 Vue2,导致本身潜力很好的 Vue3 总是显得缩手缩脚,这不得不说是一种遗憾。
不依赖 Gulp,Babel,WebPack,还能优雅地写代码吗
不知道什么时候开始,前端开发已经到了不开一个 watcher 就无法工作的地步了。不依赖 Gulp、Babel、WebPack,还能优雅地写代码吗?
那就带来回顾一下这一切是怎么发生的。
从哪开始说好呢?就从『前端打包』开始吧。
前端打包
很久以前(也就五年左右吧,但是五年前端已经大变样了),页面的 JS 压缩(混淆)一般是用谷歌的 closure compiler 做的。但是突然蹦出来个 Node.js,前端开发者就开始第一次小试牛刀了,用 Node.js 来做 JS 压缩,一般都是用 uglify-js 来做。
JS 压缩做了,CSS 压缩是不是也可以做?JS lint 是不是也可以做?自动测试是不是也可以做?文件合并是不是也可以做?
于是 grunt 应运而生,它可以帮把这些事情都做了,只需要配置一个简单的 Gruntfile 即可。
同一时期,AMD 和 CommonJS 也出现了,Node.js 用 CommonJS 加载模块,浏览器用 AMD 来加载模块。前端觉得可以统一一下,都用 CommonJS 来写,于是用上 browserify 之类的工具。
好了,这个时候一个前端项目需要有一个 Grunt(后来又有了 Gulp 等)任务用来打包前端资源,看起来就是一个标配了。
框架的兴起
前端一直吐槽新手用 jQuery 写出的「意大利面条」式的代码,于是发明的了一些框架,一开始比较火的是 MVC 框架(如 Backbone.js),火了没多久,前端发现 MVC 框架有很多相似的代码都是在做「绑定事件」「更新 view」这些事情了,于是发现了 MVVM 框架(一种早年间被微软玩过的设计模式),最著名的库就是 AngularJS。
此时的库都是不需要额外用 Grunt 做转译的。
直到 React 的出现。React 背后的工程师(显示不是前端)发明了一种新的语法——JSX,把 HTML 和 JS 混合起来写。前端看了一眼表示这才是写模板正确的姿势。唯一的问题是这种语法浏览器不支持,于是需要把 JSX 翻译成段举 JS。
此时 Grunt 大概也因为性能太低被 Gulp 取代了。
于是此时用 React 的项目一定会去用 Gulp 将 JSX 翻译成 JS。
ECMAScript 的发展
同时期,ES 发展也是非常迅猛。
IE 8 不支持 ES5,于是前端说,「IE 8 去死吧」,不想再支持 IE 8 了,因为那几年移动端发展迅猛,网页主要都是 H5 页面(不要问 H5 是不是 HTML5,不是 HTML5),所以很多前端确实不需要管 IE 8。现在想想,Windows Phone 的失败,真是前端的福音啊。
前端就开始追新了,一定要第一时间用上最新版的 JS 语法。但是即便是 Chrome 和 Firefox 也不可能岩世那么快就支持最新语法。于是前端说,不过就是在 Gulp 里再加一道转译嘛,用 Babel 把 ES 2016 的语法转译成 ES 5 就好了。
于是 Gulp 里又多了一项任务。
重新思考
经过这两三年的飞速发展,前端是不是应该重新思考一下,做一个网页之前要加这么多 Gulp 任务的初衷到底是什么?是否解决了问题。
从目前的结果来看,基本可以总结为
DOM 不好用,换成虚拟 DOM
CSS 不好用,换成 CSS in JS
浏览器支持的 JS 不好用,换成 ES 最新版语法,然后转译为浏览器支持的 JS
DOM Event 不用了,去新造一个 Event 机制。
Gulp 用握枣碧得太多了 watch 很慢,于是加上了 hot module replacement
基本把能抛弃的都抛弃了。
实际上这些变化非常适合复杂的 Web 应用,然而 90% 的页面根本不是单页面应用好吗!
能不能让写一个 CSS 一个 JS 刷新一下就能看到效果!
综上就是 baike.aiufida.com 小编关于jsx是谁发明的的知识的个人见解,如果能够提供给您解决js诞生于哪一年问题时的帮助,您可以在评论区留言点赞哟。
版权声明
本文仅代表作者观点,不代表百度立场。
本文系作者授权百度百家发表,未经许可,不得转载。