React.js中JSX的原理与关键实现

简介: 在开始开发之前,我们需要创建一个空项目文件夹

安装


  1. 初始化


npm init -y


2.安装webpack相关依赖


npm install webpack webpack-cli -D


  1. 安装babel-loader相关依赖


npm install babel-loader @babel/core @babel/preset-env -D


  1. 安装jsx支持依赖


npm install @babel/plugin-transform-react-jsx -D


配置


  1. 在根目录下创建main.js文件


此文件为入口文件。


  1. 在项目根目录下创建webpack.config.js


module.exports={
  entry:{
    main:'./main.js'
  },
  module:{
    rules:[
      {
        test:/\.js$/,
        use:{
          loader:'babel-loader',
          options:{
            presets:['@babel/preset-env'],
            plugins:[['@babel/plugin-transform-react-jsx',{pragma:'createElement'}]] // 自定义设置pragma参数,我也可以设置为我的名字:maomin
          }
        }
      }
    ]
  },
  mode:'development',
  optimization:{
    minimize: false
  }
}


  1. 创建一个reactJsx.js文件


此文件为主要逻辑文件。


开发


reactJsx.js


// 封装创建Dom节点
class ElementWrapper {
  constructor(type) {
    this.root = document.createElement(type);
  }
  setAttibute(name, value) {
    this.root.setAttibute(name, value);
  }
  appendChild(component) {
    this.root.appendChild(component.root);
  }
}
// 封装插入文本节点
class TextWrapper {
  constructor(content) {
    this.root = document.createTextNode(content);
  }
}
// 组件
export class Component {
  constructor() {
    this.props = Object.create(null); // 创建一个原型为null的空对象
    this.children = [];
    this._root = null;
  }
  setAttribute(name, value) {
    this.props[name] = value;
  }
  appendChild(component) {
    this.children.push(component);
  }
  get root() { // 取值
    if (!this._root) {
      this._root = this.render().root;
    }
    return this._root;
  }
}
// 创建节点,createElement对照 webapck.config.js 中pragma参数。
export function createElement(type, attributes, ...children) {
  let e;
  if (typeof type === "string") {
    e = new ElementWrapper(type);
  } else {
    e = new type();
  }
  for (let p in attributes) { // 循环属性
    e.setAttribute(p, attributes[p]);
  }
  let insertChildren = (children) => {
    for (let child of children) {
      if (typeof child === "string") {
        child = new TextWrapper(child);
      }
      if (typeof child === "object" && child instanceof Array) {
        insertChildren(child); // 递归
      } else {
        e.appendChild(child);
      }
    }
  };
  insertChildren(children);
  return e;
}
// 添加到Dom中
export function render(component, parentElement) {
  parentElement.appendChild(component.root);
}


main.js


import {createElement,Component,render} from './reactJsx.js'
class MyComponent extends Component {
  render(){
    return <div>
      <h1>maomin</h1>
      {this.children}
    </div>
  }
}
render(<MyComponent id="name" class="age">
  <div>xqm</div>
  <div>my girlfriend</div>
</MyComponent>,document.body)


执行


npx webpack


在dist文件夹下创建html文件,然后引入main.js,打开html文件就可以看到效果了。


微信截图_20220505193403.png


微信截图_20220505193403.png微信截图_20220505193403.png微信截图_20220505193403.png

相关文章
|
20天前
|
JavaScript 算法 前端开发
JS垃圾回收机制的原理
JS垃圾回收机制的原理
|
20天前
|
前端开发 JavaScript 开发者
React:JSX语法入门
React:JSX语法入门
31 0
|
20天前
|
JavaScript 前端开发
解释JavaScript闭包的工作原理,并举例说明其在游戏开发中的应用。
JavaScript闭包允许内部函数访问并保持对外部函数变量的引用,即使外部函数执行结束。当函数返回内部函数时,形成闭包,继承父函数作用域链。在游戏开发中,闭包用于创建具有独立状态和行为的角色实例。例如,`createCharacter`函数创建角色并返回包含属性和方法的对象,内部函数如`getHealth`、`setHealth`和`attack`通过闭包访问并操作角色的变量。这种方式确保了每个角色的状态在不同实例间独立,是实现游戏逻辑的强大工具。
15 2
|
20天前
|
JSON 缓存 前端开发
【React】React原理面试题集锦
本文集合一些React的原理面试题,方便读者以后面试查漏补缺。作者给出自认为可以让面试官满意的简易答案,如果想要了解更深刻,可以点击链接查看对应的详细博文。在此对链接中的博文作者非常感谢🙏。
56 0
|
18天前
|
Web App开发 JavaScript 前端开发
浏览器与Node.js事件循环:异同点及工作原理
浏览器与Node.js事件循环:异同点及工作原理
|
18天前
|
JavaScript 前端开发
探索JavaScript中的New操作符:原理与使用
探索JavaScript中的New操作符:原理与使用
|
19天前
|
JavaScript 前端开发
vue3中使用jsx报错React is not defined和h is not defined
vue3中使用jsx报错React is not defined和h is not defined
|
20天前
|
JavaScript 前端开发
深入了解前端框架Vue.js的响应式原理
本文将深入探讨Vue.js前端框架的核心特性之一——响应式原理。通过分析Vue.js中的数据绑定、依赖追踪和虚拟DOM等机制,读者将对Vue.js的响应式系统有更深入的理解,从而能够更好地利用Vue.js构建灵活、高效的前端应用。
|
20天前
|
XML 前端开发 JavaScript
react中JSX的详解
react中JSX的详解
19 2
|
20天前
|
编解码 JavaScript 前端开发
【专栏】介绍了字符串Base64编解码的基本原理和在Java、Python、C++、JavaScript及Go等编程语言中的实现示例
【4月更文挑战第29天】本文介绍了字符串Base64编解码的基本原理和在Java、Python、C++、JavaScript及Go等编程语言中的实现示例。Base64编码将24位二进制数据转换为32位可打印字符,用“=”作填充。文中展示了各语言的编码解码代码,帮助开发者理解并应用于实际项目。