RxJS-環境のセットアップ
この章では、RxJSをインストールします。RxJSを使用するには、次の設定が必要です。
- NodeJS
- Npm
- RxJSパッケージのインストール
NODEJSとNPMのインストール
npmを使用してRxJSをインストールするのは非常に簡単です。システムにnodejsとnpmをインストールする必要があります。NodeJSとnpmがシステムにインストールされているかどうかを確認するには、コマンドプロンプトで次のコマンドを実行してみてください。
E:\>node -v && npm -v
v10.15.1
6.4.1
バージョンを取得している場合は、nodejsとnpmがシステムにインストールされており、現在システムにバージョンが10と6であることを意味します。
何も出力されない場合は、nodejsをシステムにインストールしてください。nodejsをインストールするには、ホームページにアクセスしてくださいhttps://nodejs.org/en/download/ nodejsを使用して、OSに基づいてパッケージをインストールします。
nodejsのダウンロードページは次のようになります-
OSに基づいて、必要なパッケージをインストールします。nodejsがインストールされると、npmも一緒にインストールされます。npmがインストールされているかどうかを確認するには、ターミナルでnpm –vと入力します。npmのバージョンが表示されます。
RxJSパッケージのインストール
RxJSのインストールを開始するには、最初にというフォルダーを作成します。 rxjsproj/ ここでは、すべてのRxJSの例を練習します。
一度フォルダ rxjsproj/ 作成されたら、コマンドを実行します npm init、以下に示すプロジェクト設定用
E:\>mkdir rxjsproj
E:\>cd rxjsproj
E:\rxjsproj>npm init
Npm initコマンドは実行中にいくつかの質問をします。Enterキーを押して続行してください。npm initの実行が完了すると、作成されますpackage.json 以下に示すようにrxjsproj /内-
rxjsproj/
package.json
これで、以下のコマンドを使用してrxjsをインストールできます-
npm install ---save-dev rxjs
E:\rxjsproj>npm install --save-dev rxjs
npm notice created a lockfile as package-lock.json. You should commit this file.
npm WARN [email protected] No description
npm WARN [email protected] No repository field.
+ [email protected]
added 2 packages from 7 contributors and audited 2 packages in 21.89s
found 0 vulnerabilities
RxJSのインストールは完了です。ここで、RxJSを使用して、フォルダーを作成してみましょう。src/ 内部 rxjsproj/
これで、次のようなフォルダ構造になります-
rxjsproj/
node_modules/
src/
package.json
内部 src/ ファイルを作成する testrx.js、次のコードを記述します-
testrx.js
import { of } from 'rxjs;
import { map } from 'rxjs/operators';
map(x => x * x)(of(1, 2, 3)).subscribe((v) => console.log(`Output is: ${v}`));
コマンドプロンプトで上記のコードを実行する場合は、コマンド-を使用します。 node testrx.js、nodejsはインポートをどう処理するかわからないため、インポートのエラーが表示されます。
nodejsでインポートを機能させるには、以下に示すように、npmを使用してES6モジュールパッケージをインストールする必要があります。
E:\rxjsproj\src>npm install --save-dev esm
npm WARN [email protected] No description
npm WARN [email protected] No repository field.
+ [email protected]
added 1 package from 1 contributor and audited 3 packages in 9.32s
found 0 vulnerabilities
パッケージがインストールされると、実行できるようになります testrx.js 以下に示すファイル-
E:\rxjsproj\src>node -r esm testrx.js
Output is: 1
Output is: 4
Output is: 9
これで、RxJSがインストールされ、使用する準備ができていることを示す出力が表示されます。上記の方法は、コマンドラインでRxJSをテストするのに役立ちます。ブラウザでRxJSをテストする場合は、いくつかの追加パッケージが必要になります。
ブラウザでのRxJSのテスト
rxjsproj /フォルダー内に次のパッケージをインストールします-
npm install --save-dev babel-loader @babel/core @babel/preset-env webpack webpack-cli webpack-dev-server
E:\rxjsproj>npm install --save-dev babel-loader
@babel/core @babel/preset-env webpack webpack-cli webpack-dev-server
npm WARN [email protected] No description
npm WARN [email protected] No repository field.
npm WARN optional SKIPPING OPTIONAL DEPENDENCY: [email protected]
(node_modules\fsevents):
npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@
1.2.9: wanted {"os":"darwin","arch":"any"} (current: {"os":"win32","arch":"x64"})
+ [email protected]
+ [email protected]
+ @babel/[email protected]
+ @babel/[email protected]
+ [email protected]
+ [email protected]
added 675 packages from 373 contributors and audited 10225 packages in 255.567s
found 0 vulnerabilities
サーバーを起動してHtmlファイルを実行するには、webpack-serverを使用します。package.jsonのコマンド「publish」は、webpackを使用してすべてのjsファイルを起動およびパックするのに役立ちます。使用する最後のjsファイルであるパックされたjsファイルは、パス/ devフォルダーに保存されます。
webpackを使用するには、実行する必要があります npm run publish 以下に示すように、コマンドとコマンドがpackage.jsonに追加されます-
Package.json
{
"name": "rxjsproj",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"publish":"webpack && webpack-dev-server --output-public=/dev/",
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"devDependencies": {
"@babel/core": "^7.6.0",
"@babel/preset-env": "^7.6.0",
"babel-loader": "^8.0.6",
"esm": "^3.2.25",
"rxjs": "^6.5.3",
"webpack": "^4.39.3",
"webpack-cli": "^3.3.8",
"webpack-dev-server": "^3.8.0"
}
}
webpackを使用するには、最初にwebpack.config.jsというファイルを作成する必要があります。このファイルには、webpackを機能させるための構成の詳細が含まれています。
ファイルの詳細は次のとおりです-
var path = require('path');
module.exports = {
entry: {
app: './src/testrx.js'
},
output: {
path: path.resolve(__dirname, 'dev'),
filename: 'main_bundle.js'
},
mode:'development',
module: {
rules: [
{
test:/\.(js)$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
query: {
presets: ['@babel/preset-env']
}
}
]
}
};
ファイルの構造は上記のとおりです。現在のパスの詳細を示すパスから始まります。
var path = require('path'); //gives the current path
次は、プロパティentry、output、およびmoduleを持つmodule.exportsオブジェクトです。エントリーが出発点です。ここでは、コンパイルする開始jsファイルを指定する必要があります。
entry: {
app: './src/testrx.js'
},
path.resolve(_dirname、 'src / testrx.js')-ディレクトリ内のsrcフォルダーと、そのフォルダー内のtestrx.jsを検索します。
出力
output: {
path: path.resolve(__dirname, 'dev'),
filename: 'main_bundle.js'
},
出力は、パスとファイル名の詳細を持つオブジェクトです。パスは、コンパイルされたファイルが保存されるフォルダーを保持し、ファイル名は、.htmlファイルで使用される最終ファイルの名前を示します。
モジュール
module: {
rules: [
{
test:/\.(js)$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
query: {
presets: ['@babel/preset-env']
}
}
]
}
Moduleは、テスト、インクルード、ローダー、クエリなどのプロパティを持つルールの詳細を持つオブジェクトです。テストでは、.jsと.jsxで終わるすべてのjsファイルの詳細が保持されます。指定されたエントリポイントの最後で.jsを検索するパターンがあります。
Include ファイルの表示に使用するフォルダーを指示します。
The loader コードのコンパイルにbabel-loaderを使用します。
The query値が「@babel / preset-env」の配列であるプロパティプリセットがあります。必要なES環境に従ってコードをトランスパイルします。
最終的なフォルダ構造は次のようになります-
rxjsproj/
node_modules/
src/
testrx.js
index.html
package.json
webpack.config.js
コマンドを実行
npm run publishmain_bundle.jsファイルを含むdev /フォルダーを作成します。サーバーが起動し、以下に示すようにブラウザでindex.htmlをテストできます。
ブラウザを開き、URLを押します- http://localhost:8080/
出力はコンソールに表示されます。