ng serve
コマンドでangular-cliを使用して、毎回手動で--port
フラグを渡す必要がないようにデフォルトポートを指定するにはどうすればよいですか。
ポート4200から変更したいのですが。
@ angular/cli @ 6.x以降の更新
新しいangular.json
では、「プロジェクト」ごとにポートを指定するようになりました
"projects": {
"my-cool-project": {
... rest of project config omitted
"architect": {
"serve": {
"options": {
"port": 1337
}
}
}
}
}
利用可能なすべてのオプション:
https://github.com/angular/angular-cli/wiki/angular-workspace
あるいは、ng serveを実行するたびにポートを次のように指定します。
ng serve --port 1337
遺産:
@ angular/cli finalの更新:
angular-cli.json
内ではデフォルトでポートを指定できます。
"defaults": {
"serve": {
"port": 1337
}
}
レガシー
[email protected]でテスト済み
angular-cli
のサーバーはember-cli
プロジェクトから来ています。サーバーを構成するには、プロジェクトルートに.ember-cli
ファイルを作成します。そこにあなたのJSON設定を追加します。
{
"port": 1337
}
サーバーを再起動すると、そのポートで機能します。
ここで指定されたより多くのオプションがあります。 http://ember-cli.com/#runtime-configuration
{
"skipGit" : true,
"port" : 999,
"Host" : "0.1.0.1",
"liveReload" : true,
"environment" : "mock-development",
"checkForUpdates" : false
}
Angular 2 [email protected]、
別のポートで新しいプロジェクトを実行するには、ng serveコマンドを実行しながらポートを指定するのが1つの方法です。
ng serve --port 4201
または逆に、package.jsonファイルのスクリプト部分を編集して、後述するようにポートを開始変数に接続してから、単に「npm start」を実行することもできます。
"scripts": {
"ng": "ng",
"start": "ng serve --port 4201",
... : ...,
... : ....
}
毎回明示的にポートを定義する必要がない場合は、この方法がはるかに優れています。
代わりにnpmスクリプトを使用してください... package.jsonを編集して、スクリプトセクションにコマンドを追加してください。
{
"name": "my new project",
"version": "0.0.0",
"license": "MIT",
"angular-cli": {},
"scripts": {
"ng": "ng",
"start": "ng serve --Host 0.0.0.0 --port 8080",
"lint": "tslint \"src/**/*.ts\" --project src/tsconfig.json --type-check && tslint \"e2e/**/*.ts\" --project e2e/tsconfig.json --type-check",
"test": "ng test",
"pree2e": "webdriver-manager update --standalone false --gecko false",
"e2e": "protractor"
},
"private": true,
"dependencies": {
"@angular/common": "^2.3.1",
"@angular/compiler": "^2.3.1",
"@angular/core": "^2.3.1",
"@angular/forms": "^2.3.1",
"@angular/http": "^2.3.1",
"@angular/platform-browser": "^2.3.1",
"@angular/platform-browser-dynamic": "^2.3.1",
"@angular/router": "^3.3.1",
"core-js": "^2.4.1",
"rxjs": "^5.0.1",
"ts-helpers": "^1.1.1",
"zone.js": "^0.7.2"
},
"devDependencies": {
"@angular/compiler-cli": "^2.3.1",
"@types/jasmine": "2.5.38",
"@types/node": "^6.0.42",
"angular-cli": "1.0.0-beta.26",
"codelyzer": "~2.0.0-beta.1",
"jasmine-core": "2.5.2",
"jasmine-spec-reporter": "2.5.0",
"karma": "1.2.0",
"karma-chrome-launcher": "^2.0.0",
"karma-cli": "^1.0.1",
"karma-jasmine": "^1.0.2",
"karma-remap-istanbul": "^0.2.1",
"protractor": "~4.0.13",
"ts-node": "1.2.1",
"tslint": "^4.3.0",
"TypeScript": "~2.0.3"
}
}
それからちょうどnpm start
を実行してください
デフォルトで.angular-cli.jsonのポートを指定できます。
"defaults": {
"styleExt": "scss",
"serve": {
"port": 8080
},
"component": {}
}
Angular-cli v1.0.6でテスト済み
プロジェクト構成ファイルangular.json
は、個別に処理できる複数のプロジェクト(ワークスペース)を処理できます。
ng config projects.my-test-project.targets.serve.options.port 4201
ここでmy-test-project
部分は、ng new
コマンドで設定したプロジェクト名です。
$ ng new my-test-project
$ cd my-test-project
$ ng config projects.my-test-project.targets.serve.options.port 4201
$ ng serve
** Angular Live Development Server is listening on localhost:4201, open your browser on http://localhost:4201/ **
レガシー:
私は通常ng set
コマンドを使用して、プロジェクトレベルのAngular CLI設定を変更します。
ng set defaults.serve.port=4201
それはあなたの.angular.cli.jsonを変更し、先に述べたように ポート設定を追加します 。
この変更の後、あなたは単にng serve
を使うことができ、毎回それを指定する必要なしに好ましいポートを使うことになります。
Angular CLI:7.1.4に関する限り、 デフォルトポートの変更 を達成するための2つの一般的な方法があります。
angular.json
で、serve
部分に--port
オプションを追加し、ng serve
を使用してサーバーを起動します。
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"options": {
"browserTarget": "demos:build",
"port": 1337
},
"configurations": {
"production": {
"browserTarget": "demos:build:production"
}
}
},
package.json
で、--port
にng serve
オプションを追加し、npm start
を使用してサーバーを起動します。
"scripts": {
"ng": "ng",
"start": "ng serve --port 8000",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
Elwynが提供した答えは正しいです。しかし、e2e用の分度器設定も更新する必要があります。
Angular.jsonでは、
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"options": {
"port": 9000,
"browserTarget": "app:build"
}
}
E2e/protractor.conf.js内
exports.config = {
allScriptsTimeout: 11000,
specs: [
'./src/**/*.e2e-spec.ts'
],
capabilities: {
'browserName': 'chrome'
},
directConnect: true,
baseUrl: 'http://localhost:9000/'
}