layui table行点击tr_深入详解大佬用33行代码实现了React

2ec785c4d224aa3b1c7c2e2394e2a2aa.png

作者: 李松峰

转发连接:https://mp.weixin.qq.com/s/dIG7QxHyP-EKWH0Fq98dGQ

前言

一位伦敦的Python工程师Oliver Russell最近做了一个好玩的尝试,用33行代码“实现了”React。

他实现的“React”主要涉及如下抽象:

  • 我们传一个取得状态并返回虚拟DOM的函数
  • “React”在浏览器中将虚拟DOM渲染为真实DOM
  • 状态改变,“React”再次运行函数并返回新虚拟DOM
  • “React”高效更新真实DOM,以匹配新虚拟DOM

由此可见,这个实现的功能还十分有限。只涉及虚拟DOM生成、差异比较和真实DOM渲染。

全部实现代码如下图所示。

5a08b564abb50513c398c456c066c09c.png
  • 无注释版:https://github.com/leontrolski/leontrolski.github.io/blob/master/33-line-react.js
  • 有注释版:https://github.com/leontrolski/leontrolski.github.io/blob/master/33-line-react-with-comments.js

这个实现参考了Mithril(https://mithril.js.org/)的语法。对外主要暴露了两个函数:

  • m():Mithril风格的hyperscript辅助函数,用于创建虚拟DOM
  • m.render():DOM挂载与渲染逻辑

其中m()接收如下参数:

  • 标签名(如 'tr')及 .分隔的类名
  • (可选的){string: any}对象,包含添加给DOM节点的所有属性
  • 任意嵌套的子节点,可以是其他虚拟DOM或字符串

返回虚拟DOM对象,比如:

{    tag: 'div',    attrs: {},    classes: [],    children: [        {            tag: 'h3',            attrs: {},            classes: [],            children: [                'current player: x'            ]        },        {            tag: 'table',            attrs: {},            classes: [],            children: [                {                    tag: 'tr',                    attrs: {},                    classes: [],                    children: [...

虽然在很多人眼里这还是一个“玩具”,但用Oliver Russell的话说:“(对于一般的单面应用)用这33行代码替换React也不会有人看得出来。”为此,他还基于这个“React”写了几个例子。

Noughts and Crosses

136d0ab7617d05336fc409f285f58163.png
  • https://leontrolski.github.io/33-line-react.html

Calendar Picker

c3904f71ba48eeb2921f43b839a80453.png
  • https://leontrolski.github.io/33-line-react-calendar.html

Snake

444a87d21dd81e8ecf072c2138d0a96b.png
  • https://leontrolski.github.io/33-line-react-snake.html

笔者也基于这个“React”写了一个非常简单的ToDo:

class toDoDemo {  constructor() {    this.todos = []    this.render = () => m.render(      document.getElementById('example'),      {children: [this.showToDos()]},    )    this.render()  }  showToDos() {    return m('div', [      m('h3', 'ToDo示例'),      m('input', { placeholder: '添加todo' }),      m('button',        {          onclick: (e) => this.addTodo(e)        },        '+'       ),      m('ul',        this.todos.map((item, i) => m('li', [          m('span', item),          m('button',            {              onclick: () => this.removeTodo(i)            },            '-'           )        ])))      ])  }  removeTodo(i) {    this.todos.splice(i,1)    this.render()  }  addTodo(e) {    const input = e.target.previousSibling    const todo = input.value    if(!todo.trim()) return    input.value = ''    this.todos.push(todo)    this.render()  }}new toDoDemo()
  • https://code.h5jun.com/zelix/

有兴趣的的读者不妨花点时间研究一下这个“33-line-react”,包括上面的几个示例。

推荐React 学习相关文章

《让你的 React 组件性能跑得再快一点「实践」》

《React源码分析与实现(三):实践 DOM Diff》

《React源码分析与实现(一):组件的初始化与渲染「实践篇」》

《React源码分析与实现(二):状态、属性更新->setState「实践篇」》

《细说React 核心设计中的闪光点》

《手把手教你10个案例理解React hooks的渲染逻辑「实践」》

《React-Redux 100行代码简易版探究原理》

《手把手深入教你5个技巧编写更好的React代码【实践】》

《React 函数式组件性能优化知识点指南汇总》

《13个精选的React JS框架》

《深入浅出画图讲解React Diff原理【实践】》

《【React深入】React事件机制》

《Vue 3.0 Beta 和React 开发者分别杠上了》

《手把手深入Redux react-redux中间件设计及原理(上)【实践】》

《手把手深入Redux react-redux中间件设计及原理(下)【实践】》

《前端框架用vue还是react?清晰对比两者差异》

《为了学好 React Hooks, 我解析了 Vue Composition API》

《【React 高级进阶】探索 store 设计、从零实现 react-redux》

《写React Hooks前必读》

《深入浅出掌握React 与 React Native这两个框架》

《可靠React组件设计的7个准则之SRP》

《React Router v6 新特性及迁移指南》

《用React Hooks做一个搜索栏》

《你需要的 React + TypeScript 50 条规范和经验》

《手把手教你绕开React useEffect的陷阱》

《浅析 React / Vue 跨端渲染原理与实现》

《React 开发必须知道的 34 个技巧【近1W字】》

《三张图详细解说React组件的生命周期》

《手把手教你深入浅出实现Vue3 & React Hooks新UI Modal弹窗》

《手把手教你搭建一个React TS 项目模板》

《全平台(Vue/React/微信小程序)任意角度旋图片裁剪组件》

《40行代码把Vue3的响应式集成进React做状态管理》

《手把手教你深入浅出React 迷惑的问题点【完整版】》

作者: 李松峰

转发连接:https://mp.weixin.qq.com/s/dIG7QxHyP-EKWH0Fq98dGQ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值