ホームページ ウェブフロントエンド jsチュートリアル Npm は cli コマンドラインツールを作成します

Npm は cli コマンドラインツールを作成します

Apr 17, 2018 pm 04:14 PM
コマンドライン 道具

今回は、CLI コマンドライン ツールとしての Npm について説明します。CLI コマンド ライン ツールとしての Npm の 注意事項 について、実際のケースを見てみましょう。

はじめに

npm プラグインを作成したい場合、コマンド ラインによる操作を簡素化したい場合、怠け者でもある場合は、この記事を読む価値があります。

po オーナーの前回の記事では、独自のテンプレートのカスタマイズを紹介しましたが、po オーナーはこれに満足していないため、プロジェクトでは頻繁に新しいページ、論理スタイル、その他のファイルを手動で作成する必要があります。新しいものを作成して基本的なコードをコピーするのは非常に面倒なので、この記事を書きました。次に、po マスターに npm コマンド ライン プラグインの作成方法を段階的に説明してもらいます。

npmアカウントを登録する

npm プラグインを公開するには、まず npm アカウントを取得する必要があります。このプロセスは長くなりません。

npm公式サイト

アカウントを取得したら、npm init を通じてパッケージ

設定ファイルを生成し、情報を入力すると、ロジック コードの記述を開始できます。

コマンドエントリの書き込み

まずはプロジェクトの構造を見てみましょう

.
├── bin      //命令配置
├── README.md   //说明文档
├── index.js   //主入口
├── src      //功能文件
├── package.json //包信息
└── test     //测试用例
ログイン後にコピー
サンプルのコマンド コードはすべて bin ディレクトリに記述されています。ここで、設定ファイル パッケージ ファイルでコマンドを有効にし、設定項目 bin

 "bin": {
    "xu": "./bin/xu.js"
  },
ログイン後にコピー
を追加します。 次に、依存関係である TJ が作成したコマンダー プラグイン

npm i commander --save
ログイン後にコピー
をインストールします。 このツールを使うとコマンドコードを簡単に書くことができます

xu.js

りぃ

このファイルは

エントリ ファイル と見なすことができます。コードの最初の行を env で追加する必要があるのは、スクリプト インタプリタが Linux の異なるディレクトリにインストールされている可能性があるためです。システムのディレクトリで検索します。同時に、env はいくつかのシステム環境変数も規定します。 この書き方は主に、プログラムをさまざまなシステムに適用できるようにすることを目的としています。 このステップでは、独自の npm プラグインを簡単にテストできます

#!/usr/bin/env node
process.title = 'xu';
require('commander')
.version(require('../package').version)
.usage('<command> [options]')
.command('generate', 'generate file from a template (short-cut alias: "g")')
.parse(process.argv)
require('./xu-generate');  >>引入
ログイン後にコピー

コマンダーについては、まず作者の Github にアクセスして学習してください。パラメータについてはここでは説明しません。

xu-generate.js

$ node ./bin/xu.js
>>> 输出一些插件usage。help信息
ログイン後にコピー

これは関数コマンドで、生成コマンドを定義します。.alias('g') はコマンドの省略形で、次に .action(function(type, name){xu.run(type, name); }); となります。 function を返します。この関数は、このコマンドを定義するために必要なものです。

関数関数を書く

./src/generate.js

このファイルは、いつ

#!/usr/bin/env node
const program = require('commander');
const chalk = require('chalk')
const xu = require('../src/generate');
/**
 * Usage.
 */
program
.command('generate')
.description('quick generate your file')
.alias('g')
.action(function(type, name){
  xu.run(type, name);
});
program.parse(process.argv);
ログイン後にコピー

を入力するかを定義します 手術は完了しました。

りー

ここには 2 つの新しい依存関係があります。つまり、npm を介してインストールされたコマンド出力カラーとファイル操作プラグインです。

りー

この js ファイルは、xu-generate.js によって呼び出される run 関数をエクスポートします。パラメーターを通じてユーザーが入力した型と名前を取得し、node fs モジュールを通じて型に基づいて操作できます (ここでは依存関係が使用されています)。 、ただし原則は fs) テンプレート ファイルをプロジェクトにコピーします。

これで、プロジェクトのテンプレートファイルを素早く生成できるコマンドの開発が完了しました。

ローカルテスト

npm パッケージ開発は Web 開発とは異なり、ブラウザで直接表示し、インスタンス ディレクトリにテスト ファイルを作成してからノード テストを行うことができます。 私たちのロジックをテストするためだけに。公開後にテストする必要がある機能がある場合は、npm にローカル モジュールに接続できるリンク コマンドが用意されています。もちろん、後で公開することもできます。 テストのためにプラグインを自分でインストールすることは、プラグインを導入するのと同じです。

npmパッケージを公開する

まずプロジェクトのルートディレクトリでnpmloginを実行します

$ xu g
ログイン後にコピー

ここでエラーが発生した場合は、cnpm アドレスを使用した可能性があるため、npm ウェアハウスを元に戻す必要があります

/**
 * Created by xushaoping on 17/10/11.
 */
const fs = require('fs-extra')
const chalk = require('chalk')
exports.run = function(type, name) {
  switch (type) {
    case 'page':
      const pageFile = './src/page/' + name + '/' + name + '.vue'
      const styleFile = './src/page/' + name + '/' + name + '.less'
      fs.pathExists(pageFile, (err, exists) => {
        if (exists) {
          console.log('this file has created')
        } else {
          fs.copy('/usr/local/lib/node_modules/vue-xu-generate/src/template/page.vue', pageFile, err => {
            if (err) return console.error(err)
        
            console.log(pageFile + ' has created')
          })
          fs.copy('/usr/local/lib/node_modules/vue-xu-generate/src/template/page.less', styleFile, err => {
            if (err) return console.error(err)
        
            console.log(styleFile + ' has created')
          })
        }
      })
      break;
    case 'component':
      const componentFile = './src/components/' + name + '.vue'
      fs.pathExists(componentFile, (err, exists) => {
        if (exists) {
          console.log('this file has created')
        } else {
          fs.copy('/usr/local/lib/node_modules/vue-xu-generate/src/template/component.vue', componentFile, err => {
            if (err) return console.error(err)
          
            console.log(componentFile + ' has created')
          })
        }
      })
      break;
    case 'store':
      const storeFile = './src/store/modules' + name + '.js'
      fs.pathExists(storeFile, (err, exists) => {
        if (exists) {
          console.log('this file has created')
        } else {
          fs.copy('/usr/local/lib/node_modules/vue-xu-generate/src/template/store.js', storeFile, err => {
            if (err) return console.error(err)
          
            console.log(storeFile + ' has created')
          })
        }
      })
      break;
    default:
      console.log(chalk.red(`ERROR: uncaught type , you should input like $ xu g page demo` ))
      console.log()
      console.log(' Examples:')
      console.log()
      console.log(chalk.gray('  # create a new page'))
      console.log('  $ xu g page product')
      console.log()
      console.log(chalk.gray('  # create a new component'))
      console.log('  $ xu g component product')
      console.log()
      console.log(chalk.gray('  # create a new store'))
      console.log('  $ xu g store product')
      console.log()
      break;
  }
};
ログイン後にコピー

次に、npm パッケージを更新します。バージョン番号は前回より大きくする必要があります

追記

この時点で、エントリーレベルの npm パッケージが完成します。初めてフロントエンドを作り始めたときに、他の人のプラグインがとても良くて、簡単なインストールだけでこんなに美しくできるのを見て、とても感動したのを覚えています。見慣れないものをたくさん見て、すぐに落胆しました(ノード環境、たくさんあります。vue-cliをコピーしてコードのペアを見ただけです。賢い人は無視してください。)

学習は段階的なプロセスです。一定の基礎と長期にわたる経験がなければ、ソース コードを学習することは困難です。噛む必要がある場合はそれでも問題ありませんが、ステップバイステップほど効率は良くありません。

この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨読書:

AngualrJs でのタイマーの使用

ReactJS 操作フォームの選択

以上がNpm は cli コマンドラインツールを作成しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Debian Readdirのパフォーマンスを最適化する方法 Debian Readdirのパフォーマンスを最適化する方法 Apr 13, 2025 am 08:48 AM

Debian Systemsでは、Directoryコンテンツを読み取るためにReadDirシステム呼び出しが使用されます。パフォーマンスが良くない場合は、次の最適化戦略を試してください。ディレクトリファイルの数を簡素化します。大きなディレクトリをできる限り複数の小さなディレクトリに分割し、Readdirコールごとに処理されたアイテムの数を減らします。ディレクトリコンテンツのキャッシュを有効にする:キャッシュメカニズムを構築し、定期的にキャッシュを更新するか、ディレクトリコンテンツが変更されたときに、頻繁な呼び出しをreaddirに削減します。メモリキャッシュ(memcachedやredisなど)またはローカルキャッシュ(ファイルやデータベースなど)を考慮することができます。効率的なデータ構造を採用する:ディレクトリトラバーサルを自分で実装する場合、より効率的なデータ構造(線形検索の代わりにハッシュテーブルなど)を選択してディレクトリ情報を保存およびアクセスする

DebianがHadoopデータ処理速度を改善する方法 DebianがHadoopデータ処理速度を改善する方法 Apr 13, 2025 am 11:54 AM

この記事では、DebianシステムのHadoopデータ処理効率を改善する方法について説明します。最適化戦略では、ハードウェアのアップグレード、オペレーティングシステムパラメーターの調整、Hadoop構成の変更、および効率的なアルゴリズムとツールの使用をカバーしています。 1.ハードウェアリソースの強化により、すべてのノードが一貫したハードウェア構成、特にCPU、メモリ、ネットワーク機器のパフォーマンスに注意を払うことが保証されます。高性能ハードウェアコンポーネントを選択することは、全体的な処理速度を改善するために不可欠です。 2。オペレーティングシステムチューニングファイル記述子とネットワーク接続:/etc/security/limits.confファイルを変更して、システムによって同時に開くことができるファイル記述子とネットワーク接続の上限を増やします。 JVMパラメーター調整:Hadoop-env.shファイルで調整します

Nginxログを使用してWebサイトの速度を向上させる方法 Nginxログを使用してWebサイトの速度を向上させる方法 Apr 13, 2025 am 09:09 AM

Webサイトのパフォーマンスの最適化は、アクセスログの詳細な分析と切り離せません。 Nginx Logは、Webサイトにアクセスしているユーザーの詳細情報を記録します。このデータを巧みに使用すると、Webサイトの速度を効果的に向上させることができます。この記事では、Nginxログに基づいたいくつかのWebサイトのパフォーマンス最適化方法を紹介します。 1。ユーザーの動作分析と最適化。 NGINXログを分析することにより、ユーザーの動作を深く理解し、これに基づいてターゲットを絞った最適化を行うことができます。高周波アクセスIP識別:アクセス周波数の高いIPアドレスを見つけ、特定のコンテンツの帯域幅の増加や応答速度の改善など、これらのIPアドレスのサーバーリソース構成を最適化できます。ステータスコード分析:異なるHTTPステータスコード(404エラーなど)の頻度を分析し、ウェブサイトのナビゲーションやコンテンツ管理の問題を見つけて続行します

Debian OpenSSLがどのように中間の攻撃を防ぐか Debian OpenSSLがどのように中間の攻撃を防ぐか Apr 13, 2025 am 10:30 AM

Debian Systemsでは、OpenSSLは暗号化、復号化、証明書管理のための重要なライブラリです。中間の攻撃(MITM)を防ぐために、以下の測定値をとることができます。HTTPSを使用する:すべてのネットワーク要求がHTTPの代わりにHTTPSプロトコルを使用していることを確認してください。 HTTPSは、TLS(Transport Layer Security Protocol)を使用して通信データを暗号化し、送信中にデータが盗まれたり改ざんされたりしないようにします。サーバー証明書の確認:クライアントのサーバー証明書を手動で確認して、信頼できることを確認します。サーバーは、urlsessionのデリゲート方法を介して手動で検証できます

Debian Mail Server SSL証明書のインストール方法 Debian Mail Server SSL証明書のインストール方法 Apr 13, 2025 am 11:39 AM

Debian Mail ServerにSSL証明書をインストールする手順は次のとおりです。1。最初にOpenSSL Toolkitをインストールすると、OpenSSLツールキットがシステムに既にインストールされていることを確認してください。インストールされていない場合は、次のコマンドを使用してインストールできます。sudoapt-getUpdatesudoapt-getInstalopenssl2。秘密キーと証明書のリクエストを生成次に、OpenSSLを使用して2048ビットRSA秘密キーと証明書リクエスト(CSR)を生成します:Openss

使用されなくなったパッケージをリサイクルする方法 使用されなくなったパッケージをリサイクルする方法 Apr 13, 2025 am 08:51 AM

この記事では、役に立たないソフトウェアパッケージをきれいにし、Debianシステムのディスクスペースを解放する方法について説明します。ステップ1:パッケージリストを更新するパッケージリストが最新であることを確認してください:sudoaptupdateステップ2:インストールされたパッケージを表示します。次のコマンドを使用して、すべてのインストールされたパッケージを表示します。適性は、パッケージを安全に削除するのに役立つ提案を提供します:sudoaptitudeSearch '〜pimportant'このコマンドはタグをリストします

Debian Readdirが他のツールと統合する方法 Debian Readdirが他のツールと統合する方法 Apr 13, 2025 am 09:42 AM

DebianシステムのReadDir関数は、ディレクトリコンテンツの読み取りに使用されるシステムコールであり、Cプログラミングでよく使用されます。この記事では、ReadDirを他のツールと統合して機能を強化する方法について説明します。方法1:C言語プログラムを最初にパイプラインと組み合わせて、cプログラムを作成してreaddir関数を呼び出して結果をinclude#include#include inctargc、char*argv []){dir*dir; structdireant*entry; if(argc!= 2){(argc!= 2){

DebianのZookeeperバージョンをアップグレードする方法 DebianのZookeeperバージョンをアップグレードする方法 Apr 13, 2025 am 10:42 AM

DebianシステムのZookeeperバージョンのアップグレードは、以下の手順に従うことができます。1。アップグレード前に既存の構成とデータをバックアップすると、既存のZookeeper構成ファイルとデータディレクトリをバックアップすることを強くお勧めします。 sudocp-r/var/lib/zookeeper/var/lib/zookeeper_backupsudocp/etc/zookeeper/conf/zoo.cfg/etc/zookeeper/conf/zookeeper/z

See all articles