围观“33行代码的React”

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

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

  • 我们传一个取得状态并返回虚拟DOM的函数

  • “React”在浏览器中将虚拟DOM渲染为真实DOM

  • 状态改变,“React”再次运行函数并返回新虚拟DOM

  • “React”高效更新真实DOM,以匹配新虚拟DOM

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

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

  • 无注释版: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

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

Calendar Picker

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

Snake

  • 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”,包括上面的几个示例。

参考链接:
  • https://leontrolski.github.io/33-line-react.html

  • https://news.ycombinator.com/item?id=22776753

编者按:本文作者李松峰,资深技术图书译者,翻译出版过40余部技术及交互设计专著,

现任360奇舞团Web前端开发资深专家,360前端技术委员会委员、W3C AC代表。

转载自奇舞周刊


在这里留言哦


往期精彩回顾

图像识别辅助处理系统权限弹框

360技术中台招聘啦!!

实习招聘|360云平台火热招聘中

360技术公众号

技术干货|一手资讯|精彩活动

扫码关注我们

资源下载链接为: https://pan.quark.cn/s/5c50e6120579 在Android移动应用开发中,定位功能扮演着极为关键的角色,尤其是在提供导航、本地搜索等服务时,它能够帮助应用获取用户的位置信息。以“baiduGPS.rar”为例,这是一个基于百度地图API实现定位功能的示例项目,旨在展示如何在Android应用中集成百度地图的GPS定位服务。以下是对该技术的详细阐述。 百度地图API简介 百度地图API是由百度提供的一系列开放接口,开发者可以利用这些接口将百度地图的功能集成到自己的应用中,涵盖地图展示、定位、路径规划等多个方面。借助它,开发者能够开发出满足不同业务需求的定制化地图应用。 Android定位方式 Android系统支持多种定位方式,包括GPS(全球定位系统)和网络定位(通过Wi-Fi及移动网络)。开发者可以根据应用的具体需求选择合适的定位方法。在本示例中,主要采用GPS实现高精度定位。 权限声明 在Android应用中使用定位功能前,必须在Manifest.xml文件中声明相关权限。例如,添加<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />,以获取用户的精确位置信息。 百度地图SDK初始化 集成百度地图API时,需要在应用启动时初始化地图SDK。通常在Application类或Activity的onCreate()方法中调用BMapManager.init(),并设置回调监听器以处理初始化结果。 MapView的创建 在布局文件中添加MapView组件,它是地图显示的基础。通过设置其属性(如mapType、zoomLevel等),可以控制地图的显示效果。 定位服务的管理 使用百度地图API的LocationClient类来管理定位服务
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值