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

vue-cli-plugin-nid

v1.2.10

Published

这是[宁皓网](https://ninghao.net)内部项目使用的一个 Vue CLI 插件,在使用了 TypeScript 的 Vue 项目里,可以用命令生成应用需要的组件与 store 模块。

Downloads

154

Readme

Vue CLI 插件

这是宁皓网内部项目使用的一个 Vue CLI 插件,在使用了 TypeScript 的 Vue 项目里,可以用命令生成应用需要的组件与 store 模块。

安装

在终端,项目所在目录的下面,使用 npm install 或 yarn add 安装 vue-cli-plugin-nid 这个包。

yarn add vue-cli-plugin-nid —D

然后执行:

vue invoke vue-cli-plugin-nid

上面这个命令只需要执行一次,它会在项目的 package.json 文件的 scripts 里面添加几个自定义的命令,使用 npm run 可以运行这些命令。

{
  ...
  "scripts": {
    ...
    "gc": "vue invoke vue-cli-plugin-nid --component",
    "generate:component": "vue invoke vue-cli-plugin-nid --component",
    ...
  },
  ...
}

命令都有一个简化版,比如 generate:component 命令的简化版是 gc,运行这个命令可以执行 npm run gc,后面是一些选项与对应的值,这些东西都可以放在两个小横线的后面,比如 npm run gc -- comment-index

组件

生成的组件可以使用 generate:component 或 gc 命令。

示例:

`npm run generate:component -- comment-index`

上面命令会生成一个 comment-index 组件,还有组件对应的样式表,生成的组件默认会放在 src/comment/index 目录的下面。

src/comment
└── index
    ├── comment-index.vue
    └── styles
        └── comment-index.css

命令选项

  • path:指定组件位置
  • parent:指定组件的父组件
  • vuex:指定组件内用的 vuex 帮手方法

指定具体位置

执行生成组件命令时可以用 path 选项指定这个组件的具体存放的位置。

示例:

`npm run generate:component -- comment-list --path comment/index/components`

上面这个命令会创建一个组件,位置是 src/comment/index/components/comment-list.vue。

导入 Vuex 帮手

要在生成的组件里使用 vuex 提供的帮手,可以通过 vuex 选项指定具体需要的帮手方法,如果不特别设置具体的方法,就会在组件里导入使用 vuex 提供的 mapGetters, mapMutations, mapActions 这几个帮手方法。

示例:

npm run generate:component -- comment-list \
  --path comment/index/components \
  --vuex mapGetters,mapActions

这会在生成的组件里导入 mapGetters 与 mapActions。

import { mapGetters, mapActions } from 'vuex';

或者也可以不具体设置需要的帮手方法:

npm run generate:component -- comment-list \
  --path comment/index/components \
  --vuex

指定父组件

生成组件的时候你可以设置这个组件的父组件,这样命令会找到这个父组件,在它里面导入使用新生成的这个组件。

示例:

npm run generate:component -- comment-list \
  --path comment/index/components \
  --parent comment-index

上面这个命令会生成一个 comment-list 组件,然后在 comment-index 组件里导入使用了这个新生成的组件。这个 parent 选项的值可以直接使用父组件的名字,或者也可以加上具体的位置,比如 comment/index/comment-index。

src/comment/index/comment-index.vue

<template>
  <div class="comment-index">
    <CommentList />
    ...
  </div>
</template>

<script>
...
import CommentList from '@/comment/index/components/comment-list';

export default defineComponent({
  name: 'CommentIndex',
  ...

  /**
   * 使用组件
   */
  components: {
    CommentList,
  },
});
</script>
...

Store

使用 generate:store 或 gs 命令可以生成需要的 store 模块。

示例:

`npm run generate:store -- comment`

上面命令会生成一个 store 模块,位置是 comment/comment.store.ts。

命令选项

  • parent:指定父 store 模块
  • module:在父 store 模块里注册的名字
  • action:添加动作
  • method:在动作里请求接口用的方法
  • api:在动作里请求的接口
  • resource:指定动作请求的资源

指定父模块

生成 store 模块的时候可以用 parent 选项设置父模块,另外可以配合 module 选项设置在父 store 模块那里注册的名字。

示例:

npm run generate:store -- comment-create \
  --parent comment/comment \
  --module create

上面命令会生成一个 store 模块,位置是 comment/create/comment-create.store。在 comment/comment.store.ts 里面会导入这个新生成的模块,并且在 modules 选项会用 create 这个命令注册这个新生成的 store 模块。

src/comment/comment.store.ts

...
import {
  CommentCreateStoreState,
  commentCreateStoreModule,
} from '@/comment/create/comment-create.store';

export interface CommentStoreState {
  create: CommentCreateStoreState;
  ...
}

export const commentStoreModule: Module<CommentStoreState, RootState> = {
  ...

  /**
   * 模块
   */
  modules: {
    create: commentCreateStoreModule,
  },
};

添加动作

在生成 store 模块的时候,可以使用 action 选项在 store 模块里添加一个请求接口时需要用的动作。

示例:

`npm run generate:store -- comment-index --action getComments`

添加的动作有个默认的参数叫 options,执行命令时可以用 actionParam 选项设置动作参数的名字,还可以用 method 选项设置请求接口用的方法,用 api 选项设置要请求的接口地址。

示例:

npm run generate:store -- comment-create \
  --action createComment \
  --method post \
  --api comments

src/comment/create/comment-create.store.ts

...

export interface CreateCommentOptions {
  data?: null;
}

export const commentCreateStoreModule: Module<CommentCreateStoreState, RootState> = {
  ...

  /**
   * 动作
   */
  actions: {
    async createComment({ commit }, options: CreateCommentOptions = {}) {
      commit('setLoading', true);

      try {
        const response = await apiHttpClient.post(`comments`);
        commit('setLoading', false);

        return response;
      } catch (error) {
        ...    
      }
    },    
  },
};

添加资源

用 resource 选项可以设置动作请求回来的资源,这样会在 store 的 state、getters 与 mutations 里添加对应的东西。

示例:

npm run generate:store -- comment-index \
  --action getComments \
  --resource comments:Array:CommentListItem

resource 选项的值分成了三部分,中间用冒号分隔开,第一部分是资源的名字,第二部分说明这个资源是 Array,第三部分是数据项目的类型。

动作预处理

如果 store 里的动作比较复杂,可以将其分成预处理(preProcess)与后处理(postProcess),就是在执行这个动作之前可以派发一个预处理动作,请求完成以后可以派发一个后处理动作。在命令里使用 pre 与 post 选项可以添加动作的预处理与后处理。

示例:

npm run generate:store -- comment-index \
  --action getComments \
  --resource comments:Array:CommentListItem \
  --pre --post

src/comment/index/comment-index.store.ts

...
export const commentIndexStoreModule: Module<CommentIndexStoreState, RootState> = {
  
  /**
   * 动作
   */
  actions: {
    async getComments({ commit, dispatch }, options: GetCommentsOptions = {}) {
      dispatch('getCommentsPreProcess', options);
      
      try {
        const response = await apiHttpClient.get(`resources`);
        
        dispatch('getCommentsPostProcess', response);
        
        return response;
      } catch (error) {
        ...
      }
    },

    async getCommentsPreProcess({ commit }, options: GetCommentsOptions = {}) {
      commit('setLoading', true);
    },

    async getCommentsPostProcess({ commit }, response) {
      commit('setLoading', false);
      commit('setComments', response.data);
    },
  },
};

添加 State

在已经存在的 store 模块里,可以用 gss 命令添加数据,命令会自动添加数据以及数据的获取器还有修改器。

示例:

`npm run gss ``--`` totalPages``:number``:1`` ``--``to comment-index`

上面这个命令会在 comment-index 这个 store 模块里添加一个数据,名字叫 totalPages,类型是 number,默认值是 1。

src/comment/index/comment-index.store.ts

...
export interface CommentIndexStoreState {
  totalPages: number;
  ...
}
...
export const commentIndexStoreModule: Module<...> = {
  ...
  /**
   * 数据
   */
  state: {
    totalPages: 1,
    ...
  } as CommentIndexStoreState,

  /**
   * 获取器
   */
  getters: {
    totalPages(state) {
      return state.totalPages;
    },
    ...
  },

  /**
   * 修改器
   */
  mutations: {
    setTotalPages(state, data) {
      state.totalPages = data;
    },
    ...
  },
  ...
};

导入

使用命令快速导入组件与要使用的 vuex 帮手方法。

导入组件

在组件里导入使用其它的组件有几个步骤,首先要导入组件,然后在组件的 components 里注册导入的组件,最后要在组件模板里使用导入并注册的组件。

使用 import:component 或者 ic 命令,可以在组件里导入使用其它的组件,如果需要导入多个组件,中间用逗号分隔开。然后用 to 选项设置目标组件。

示例:

`npm run import:component -- user-avatar,user-name --to comment-create`

上面这个命令可以在 comment-create 这个组件里导入使用项目里的 UserAvatar 与 UserName 组件,命令会自动在项目里查找这些组件,所以不需要设置要导入的这些组件的具体路径。

导入 Vuex

使用 import:vuex 或 iv 命令,可以在组件里导入使用 vuex 的帮手方法,用 to 这个选项设置目标组件。帮手方法的名字也可以使用简写形式,比如 ms, mg, ma, mm,分别对应的是 mapState,mapGetters,mapActions 还有 mapMutations。

示例:

`npm run import:vuex -- mapGetters,mapActions --to comment-create`

上面命令会在项目的 comment-create 组件里导入 vuex 里的 mapGetters 与 mapActions 这两个帮手方法。