首页前端开发JavaScript一文知晓JSX原理(推荐)

一文知晓JSX原理(推荐)

时间2024-01-31 04:08:03发布访客分类JavaScript浏览699
导读:收集整理的这篇文章主要介绍了一文知晓JSX原理(推荐),觉得挺不错的,现在分享给大家,也给大家做个参考。JSX原理要明白JSX的原理,需要先明白如何使用JavaScript对象来表现一个DOM元素的结构。看下面的DOM结构:<div...
收集整理的这篇文章主要介绍了一文知晓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])

所谓的 JSX 其实就是 JavaScript 对象,所以使用 React 和 JSX 的时候一定要经过编译的过程

JSX — 使用react构造组件,bable进行编译 —> JavaScript对象 — ReactDOM.render() —> DOM元素 —> 插入页面

推荐学习:《js基础教程

以上就是一文知晓JSX原理(推荐)的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: 怎么利用Node.js进行html页面跳转下一篇:聊聊JavaScript中的7种位运算符...猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员load

若转载请注明出处: 一文知晓JSX原理(推荐)
本文地址: https://pptw.com/jishu/593460.html
C ++控制语句的使用 聊聊JavaScript中的7种位运算符,看看在实战中如何妙用?

游客 回复需填写必要信息