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

kylin-babel-plugin-decorators-inject

v6.22.9

Published

Externalise references to helpers and builtins, automatically polyfilling your code without polluting globals

Downloads

6

Readme

babel-plugin-decorators-inject

options

  • className
  • propertyName
  • propertyIgnoreName
  • componentsPropertyName
  • enableComponentLazyRequire
  • injectComponentName
  • enableRenderInjectH

针对 标记了className这个装饰器的class内的所有property, 自动注入className.propertyName的装饰器, 除非property的装饰器列表中存在className.propertyNamepropertyIgnoreName

针对 标记了className这个装饰器的class内的非staticclassProperty中,如果名称为componentsPropertyName 那么认为其是vue的options.components,将其标识符的import引入做懒加载处理。该功能默认关闭,通过enableComponentLazyRequire来开启

针对 标记了className这个装饰器的class内的名为render的成员方法,如果在函数作用域没有对h的引用,并且参数列表为空,会改写参数列表为["h"]。 该功能默认关闭,通过enableRenderInjectH来开启

针对 未指定name成员属性,成员方法的,自动注入。该功能默认关闭。

example

组件懒加载

  • input
import { Component, Property }
import B from './b.vue';

@Component
class A {
  components = {
    B
  }
}
  • output
import { Component, Property }

@Component
class A {
  components = {
    B: function lazyRequire(resolve) {
      resolve( require('./b.vue').default || require('./b.vue') )
    }
  }
}

注入property

  • input
import { Component, Property }

@Component
class A {
  data = {a:1}
  
  @Component.Property
  props = 2
  
  @Property
  extends = {}

}
  • output
import { Component, Property }

@Component
class A {
  @Component.Property  // 自动补全 
  data = {a:1}
  
  @Component.Property // 检测到member存在不补全 
  props = 2

  @Property  // 检测到ignore存在不补全 
  extends = {}
}