加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

不用编译的jsx与react框架构想

发布时间:2020-12-15 07:33:43 所属栏目:百科 来源:网络整理
导读:现在react大红大紫,但它也有一个致命的缺陷,就是依赖于babel编译。随着浏览器的进化,react社区的许多语法糖都可以直接用,但jsx这个facebook的私货则没有办法了。换言之,jsx是我们直接用react的最大障碍。不处理它,就怎么得上babel,就得上webpack。 我

现在react大红大紫,但它也有一个致命的缺陷,就是依赖于babel编译。随着浏览器的进化,react社区的许多语法糖都可以直接用,但jsx这个facebook的私货则没有办法了。换言之,jsx是我们直接用react的最大障碍。不处理它,就怎么得上babel,就得上webpack。

我们定义一个组件通常是这样

class ShoppingList extends React.Component {
  render() {
    return (
      <div className="shopping-list">
        <h1>Shopping List for {this.props.name}</h1>
        <ul>
          <li>Instagram</li>
          <li>WhatsApp</li>
          <li>Oculus</li>
        </ul>
      </div>
    );
  }
}

render方法是jsx出现的地方。

我们可以劫持一下这方法。

Component.prototype.render = function(){
    return this.compile(this.$jsx)
}

然后$jsx属性是用es6的模块字符串来定义JSX

$jsx: `<div className="shopping-list">
        <h1>Shopping List for {this.props.name}</h1>
        <ul>
          <li>Instagram</li>
          <li>WhatsApp</li>
          <li>Oculus</li>
        </ul>
      </div>`

compile方法里面实现一个类似jsx的模板引擎,然后将this传进去,但得jsx编译后的对象组。

react本身也巨复杂,现在市面上有许多迷你化的react实现,可以实现一个小型的react。去掉其PropTypes(这个在生产环境通常会压缩掉),Children(这个只用于内部),Mixin(这个官方也不建议使用)等功能。

有关JSX模板引擎,我已经搞得差不多,欢迎大家参与进来。

https://github.com/RubyLouvre...

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读