JSX的原理怎样理解?一文带你看懂
Admin 2022-01-14 群英技术资讯 1266 次浏览
这篇文章给大家分享的是JSX的原理,JSX 是 JavaScript 对象。这篇我们一步步来分析和理解JSX的原理,文中的示例代码介绍得很详细,有需要的朋友可以了解看看,接下来就跟随小编一起学习一下吧。
JSX原理要明白JSX的原理,需要先明白如何使用JavaScript对象来表现一个DOM元素的结构。
看下面的DOM结构:
<div class='app' id='appRoot'>
<h1 class='title'>欢迎进入React的世界</h1>
<p>
React.js 是一个帮助你构建页面 UI 的库
</p>
</div> 上面这个HTML所有的信息我们都可以使用JavaScript对象来表示:
{
tag: 'p',
attrs: { className: 'app', id: 'appRoot'},
children: [
{
tag: 'h1',
attrs: { className: 'title' },
children: ['欢迎进入React的世界']
},
{
tag: 'p',
attrs: null,
children: ['React.js 是一个构建页面 UI 的库']
}
]
} 但是这样用JavaScript写起来太长了,而且结构也不清晰,使用HTML的方式就很方便。
于是React.js就把JavaScript的语法扩展了一下,允许在JavaScript代码中编写类似HTML标签结构的语法,这样就方便多了,编译的过程会把类似HTML的JSX结构转换为JavaScript的对象结构。
import React from 'react'
import ReactDOM from 'react-dom'
class App extends React.Component {
render () {
return (
<p className='app' id='appRoot'>
<h1 className='title'>欢迎进入React的世界</h1>
<p>
React.js 是一个构建页面 UI 的库
</p>
</p>
)
}
}
ReactDOM.render(
<App />,
document.getElementById('root')
) 转换为
import React from 'react'
import ReactDOM from 'react-dom'
class App extends React.Component {
render () {
return (
React.createElement(
"p",
{
className: 'app',
id: 'appRoot'
},
React.createElement(
"h1",
{ className: 'title' },
"欢迎进入React的世界"
),
React.createElement(
"p",
null,
"React.js 是一个构建页面 UI 的库"
)
)
)
}
}
ReactDOM.render(
React.createElement(App),
document.getElementById('root')
) React.createElement会构建一个 JavaScript 对象来描述你 HTML 结构的信息,包括标签名、属性、还有子元素等, 语法为
React.createElement( type, [props], [...children] )
使用 React 和 JSX 的时候一定要经过编译的过程
JSX — 使用react构造组件,bable进行编译 —> JavaScript对象 —
ReactDOM.render() —> DOM元素 —> 插入页面
现在大家对于JSX的原理应该都有所了解了吧,希望大家阅读完这篇文章能有所收获。最后,想要了解更多JSX的内容,大家可以关注群英网络其它相关文章。
文本转载自PHP中文网
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
jquery隐藏dl元素的方法:1、利用“$(dl元素)”语句获取指定的dl元素对象;2、利用hide()方法将获取到的dl元素对象隐藏起来,语法为“dl元素对象.hide();”。
这篇文章主要介绍了解决vue项目本地启动时无法携带cookie,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
JavaScript中hash是什么意思?hash其实就是指的是哈希表,那么对于哈希表我们怎么样来理解呢?构造方法和使用方法是什么呢?下文有很详细的介绍,有需要的朋友可以了解看看,接下来就跟随小编来一起学习一下吧!
这篇文章我们来了解jQuery怎样删除子元素的相关内容,在删除子元素之前,首先我们需要先获取子元素,这里需要使用children()方法来获取子元素对象,然后再用remove()方法就能删除子元素了,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
本篇文章带大家聊聊Node中的各种I/O模型,介绍一下阻塞式I/O模型、非阻塞式I/O模型和非阻塞异步I/O,希望对大家有所帮助!
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008