npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

react-magic-component

v0.1.8-alpha.5

Published

React component with binding events or lifecycles by selector

Downloads

14

Readme

react-magic-component

React component with binding events or lifecycles by selector

Features

  • initMagic初始化注入环境,建议在main文件中执行;

  • 施展魔法的方式:

    • 使用create创建组件;
    • 定义组件时包含getMagicConfig方法;
    • 使用组件时包含[data-]magicCong属性;
    • props中包含[data-]magic-*属性;
  • 能施展的魔法包括:

    • 特定的props,默认有locale、language、style;
    • react-redux的connect;
    • 组件的生命周期;
    • 组件的事件;
  • 绑定生命周期和事件时:

    有三个对象需要注意: 目标组件/标签(elInst)、方法源组件(mtInst)、数据源组件(dsInst)

    • 数据源组件指回调函数依赖的逻辑数据所在的组件。一般指你在哪个组件上定义魔法,该组件就是数据源组件。
    • 方法源组件指回调函数的来源。如果是匿名函数或不包含.,则与数据源组件相同,反则用Xxx.method设定,方法源则为Xxx
    • this指向: 生命周期指向目标组件,事件指向方法源组件;
    • 回调函数的后两个参数: 生命周期分别为[mtInst, dsInst],事件分别为[elInst, dsInst];
    • 如果事件名(或方法名)后跟上:0,则不覆盖old,非零或默认覆盖;
    • 如果事件名(或方法名)后跟上:^0,则new->old顺序执行,默认按old->new;
    • 原生命周期函数的返回值会是新函数的第一个值,覆盖或无原生命函数则是undefined;
  • 魔法组件不影响普通嵌套,不会像connect私自加一层组件(HOC);

  • 请尽量不要在最外层组件如App上设置魔法,原因是外层组件会在mount改写前执行而影响注入;

  • [data-]magic-*属性只能设置为string类型,如果不设置来源(Xxx.method)则寻找有此方法的最靠近的祖父魔法组件;【非冒泡式】

Examples

old:

class LoggingButton extends React.Component {
  // This syntax ensures `this` is bound within handleClick.
  // Warning: this is *experimental* syntax.
  handleClick = () => {
    console.log('this is:', this);
  }

  render() {
    return (
      <button onClick={this.handleClick}>
        Click me
      </button>
    );
  }
}

new:

function LoggingButton (props, context) {
  return (
    <button>
      Click me
    </button>
  );
}

create(LoggingButton, {
  props: {
    'onClick button': 'handleClick'
  },
  handleClick() {
    console.log('this is:', this); // this -> LoggingButton
  }
});

And it's cooler if you use decorator syntax. (ES7)

@create({
  props: {
    componentDidMount() {
      console.log('Component did mount');
    }
  }
})
class Bar extends React.Component {
  render() {}
}

Quick Start

License

MIT