Angular 2शुरुआत एंगुलर 2 से हुई


टिप्पणियों

यह खंड विभिन्न परिवेशों में उपयोग के लिए Angular2 + को स्थापित करने और कॉन्फ़िगर करने और समुदाय द्वारा विकसित कोणीय- cli जैसे IDE के उपकरणों का उपयोग करने का एक सिंहावलोकन प्रदान करता है।

एंगुलर का पिछला संस्करण एंगुलरजेएस है या जिसे एंगुलर 1 भी कहा जाता है। यहां देखें प्रलेखन

संस्करण

संस्करण रिलीज़ की तारीख
4.3.3 2017/08/02
4.3.2 2017/07/26
4.3.1 2017/07/19
4.3.0 2017/07/14
4.2.0 2017/06/08
4.1.0 2017/04/26
4.0.0 2017/03/23
2.3.0 2016/12/08
2.2.0 2016/11/14
2.1.0 2016/10/13
2.0.2 2016/10/05
2.0.1 2016/09/23
2.0.0 2016/09/14
2.0.0-rc.7 2016/09/13
2.0.0-rc.6 2016/08/31
2.0.0-rc.5 2016/08/09
2.0.0-rc.4 2016/06/30
2.0.0-rc.3 2016/06/21
2.0.0-rc.2 2016/06/15
2.0.0-rc.1 2016/05/03
2.0.0-rc.0 2016/05/02

नोड्यूलर / एक्सप्रेसजेज बैकएंड (http उदाहरण सहित) के साथ कोणीय 2 के साथ आरंभ करना

हम एक सरल "हैलो वर्ल्ड!" Angular2 2.4.1 ( @NgModule परिवर्तन) के साथ एक नोड के साथ एप्लिकेशन। js (एक्सप्रेस) बैकएंड।

आवश्यक शर्तें

फिर विश्व स्तर पर टाइपस्क्रिप्ट स्थापित करने के लिए npm install -g typescript या yarn global add typescript चलाएँ

रोडमैप

चरण 1

हमारे ऐप के लिए एक नया फ़ोल्डर (और हमारे बैक-एंड का रूट डायर) बनाएं। चलो इसे Angular2-express

कमांड लाइन :

mkdir Angular2-express
cd Angular2-express
 

चरण 2

हमारे node.js ऐप के लिए package.json (निर्भरता के लिए) और app.js (बूटस्ट्रैपिंग के लिए) node.js

package.json:

{
  "name": "Angular2-express",
  "version": "1.0.0",
  "description": "",
  "scripts": {
    "start": "node app.js"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "body-parser": "^1.13.3",
    "express": "^4.13.3"
  }
}
 

app.js:

var express = require('express');
var app = express();
var server = require('http').Server(app);
var bodyParser = require('body-parser');

server.listen(process.env.PORT || 9999, function(){
    console.log("Server connected. Listening on port: " + (process.env.PORT || 9999));
});

app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}) );

app.use( express.static(__dirname + '/front' ) );

app.get('/test', function(req,res){ //example http request receiver
  return res.send(myTestVar);
});

//send the index.html on every page refresh and let angular handle the routing
app.get('/*',  function(req, res, next) {
    console.log("Reloading");
    res.sendFile('index.html', { root: __dirname }); 
});
 

फिर निर्भरता स्थापित करने के लिए एक npm install या yarn चलाएं।

अब हमारा बैक-एंड स्ट्रक्चर पूरा हो गया है। चलिए आगे-आगे चलते हैं।

चरण 3

हमारा फ्रंट-एंड हमारे Angular2-express फ़ोल्डर के front फ़ोल्डर में होना चाहिए।

कमांड लाइन:

mkdir front
cd front
 

जैसे हमने अपने बैक-एंड के साथ किया वैसे ही हमारे फ्रंट-एंड को भी डिपेंडेंसी फाइलों की जरूरत है। चलो आगे बढ़ते हैं और निम्नलिखित फाइलें बनाते हैं: package.json , systemjs.config.js , tsconfig.json

package.json :

{
  "name": "Angular2-express",
  "version": "1.0.0",
  "scripts": {
    "tsc": "tsc",
    "tsc:w": "tsc -w"
  },
  "licenses": [
    {
      "type": "MIT",
      "url": "https://github.com/angular/angular.io/blob/master/LICENSE"
    }
  ],
  "dependencies": {
    "@angular/common": "~2.4.1",
    "@angular/compiler": "~2.4.1",
    "@angular/compiler-cli": "^2.4.1",
    "@angular/core": "~2.4.1",
    "@angular/forms": "~2.4.1",
    "@angular/http": "~2.4.1",
    "@angular/platform-browser": "~2.4.1",
    "@angular/platform-browser-dynamic": "~2.4.1",
    "@angular/platform-server": "^2.4.1",
    "@angular/router": "~3.4.0",
    "core-js": "^2.4.1",
    "reflect-metadata": "^0.1.8",
    "rxjs": "^5.0.2",
    "systemjs": "0.19.40",
    "zone.js": "^0.7.4"
  },
  "devDependencies": {
    "@types/core-js": "^0.9.34",
    "@types/node": "^6.0.45",
    "typescript": "2.0.2"
  }
}
 

systemjs.config.js:

/**
 * System configuration for Angular samples
 * Adjust as necessary for your application needs.
 */
(function (global) {
  System.config({
    defaultJSExtensions:true,
    paths: {
      // paths serve as alias
      'npm:': 'node_modules/'
    },
    // map tells the System loader where to look for things
    map: {
      // our app is within the app folder
      app: 'app',
      // angular bundles
      '@angular/core': 'npm:@angular/core/bundles/core.umd.js',
      '@angular/common': 'npm:@angular/common/bundles/common.umd.js',
      '@angular/compiler': 'npm:@angular/compiler/bundles/compiler.umd.js',
      '@angular/platform-browser': 'npm:@angular/platform-browser/bundles/platform-browser.umd.js',
      '@angular/platform-browser-dynamic': 'npm:@angular/platform-browser-dynamic/bundles/platform-browser-dynamic.umd.js',
      '@angular/http': 'npm:@angular/http/bundles/http.umd.js',
      '@angular/router': 'npm:@angular/router/bundles/router.umd.js',
      '@angular/forms': 'npm:@angular/forms/bundles/forms.umd.js',
      // other libraries
      'rxjs':                      'npm:rxjs',
      'angular-in-memory-web-api': 'npm:angular-in-memory-web-api',
    },
    // packages tells the System loader how to load when no filename and/or no extension
    packages: {
      app: {
        main: './main.js',
        defaultExtension: 'js'
      },
      rxjs: {
        defaultExtension: 'js'
      }
    }
  });
})(this);
 

tsconfig.json:

{
  "compilerOptions": {
    "target": "es5",
    "module": "commonjs",
    "moduleResolution": "node",
    "sourceMap": true,
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "removeComments": false,
    "noImplicitAny": false
  },
  "compileOnSave": true,
  "exclude": [
    "node_modules/*"
  ]
}
 

फिर निर्भरता स्थापित करने के लिए एक npm install या yarn चलाएं।

अब जब हमारी निर्भरता की फाइलें पूरी हो गई हैं। चलिए अपने index.html पर चलते हैं:

index.html:

<html>
  <head>
    <base href="/">
    <title>Angular2-express</title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 1. Load libraries -->
     <!-- Polyfill(s) for older browsers -->
    <script src="node_modules/core-js/client/shim.min.js"></script>
    <script src="node_modules/zone.js/dist/zone.js"></script>
    <script src="node_modules/reflect-metadata/Reflect.js"></script>
    <script src="node_modules/systemjs/dist/system.src.js"></script>
    <!-- 2. Configure SystemJS -->
    <script src="systemjs.config.js"></script>
    <script>
      System.import('app').catch(function(err){ console.error(err); });
    </script>
    
  </head>
  <!-- 3. Display the application -->
  <body>
    <my-app>Loading...</my-app>
  </body>
</html>
 

अब हम अपना पहला घटक बनाने के लिए तैयार हैं। हमारे front फोल्डर के अंदर एक app नाम का फोल्डर बनाएं।

कमांड लाइन:

mkdir app
cd app
 

चलिए main.ts , app.module.ts , app.component.ts नाम की निम्न फाइलें app.component.ts

main.ts:

import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';

import { AppModule } from './app.module';

const platform = platformBrowserDynamic();
platform.bootstrapModule(AppModule);
 

app.module.ts:

import { NgModule }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { HttpModule } from "@angular/http";

import { AppComponent }   from './app.component';

@NgModule({
  imports:      [ 
    BrowserModule,
    HttpModule    
  ],
  declarations: [ 
    AppComponent
  ],
  providers:[ ],
  bootstrap:    [ AppComponent ]
})
export class AppModule {}
 

app.component.ts:

import { Component } from '@angular/core';
import { Http } from '@angular/http';

@Component({
  selector: 'my-app',
  template: 'Hello World!',
  providers: []
})
export class AppComponent { 
  constructor(private http: Http){
    //http get example
    this.http.get('/test')
     .subscribe((res)=>{
       console.log(res);
     });
  }
}
 

इसके बाद, टाइपस्क्रिप्ट फ़ाइलों को जावास्क्रिप्ट फ़ाइलों के लिए संकलित करें। वर्तमान dir (Angular2- एक्सप्रेस फ़ोल्डर के अंदर) से 2 स्तर ऊपर जाएं और नीचे कमांड चलाएं।

कमांड लाइन:

cd ..
cd ..
tsc -p front
 

हमारी फ़ोल्डर संरचना इस प्रकार दिखनी चाहिए:

Angular2-express
├── app.js
├── node_modules
├── package.json
├── front
│   ├── package.json
│   ├── index.html
│   ├── node_modules
│   ├── systemjs.config.js
│   ├── tsconfig.json
│   ├── app
│   │   ├── app.component.ts
│   │   ├── app.component.js.map
│   │   ├── app.component.js
│   │   ├── app.module.ts
│   │   ├── app.module.js.map
│   │   ├── app.module.js
│   │   ├── main.ts
│   │   ├── main.js.map
│   │   ├── main.js
 

अंत में, Angular2- एक्सप्रेस फ़ोल्डर के अंदर, कमांड लाइन में node app.js कमांड node app.js । अपना पसंदीदा ब्राउज़र खोलें और अपने ऐप को देखने के लिए localhost:9999 देखें।

कोणीय-क्ली के बिना कोणीय 2 के साथ शुरू करना।

कोणीय 2.0.0-आरसी .4

इस उदाहरण में हम "हैलो वर्ल्ड!" सादगी के लिए केवल एक मूल घटक ( AppComponent ) के साथ ऐप।

आवश्यक शर्तें:

  • Node.js v5 या बाद का
  • npm v3 या बाद का

नोट: आप कंसोल / टर्मिनल में node -v और npm -v चलाकर संस्करणों की जांच कर सकते हैं।

चरण 1

अपनी परियोजना के लिए एक नया फ़ोल्डर बनाएँ और दर्ज करें। चलो इसे angular2-example

mkdir angular2-example
cd angular2-example
 

चरण 2

इससे पहले कि हम अपना ऐप कोड लिखना शुरू करें, हम नीचे दी गई 4 फाइलें जोड़ेंगे: package.json , tsconfig.json , typings.json और systemjs.config.js

अस्वीकरण: वही फाइलें आधिकारिक 5 मिनट क्विकस्टार्ट में पाई जा सकती हैं।

package.json - हमें npm के साथ सभी निर्भरताएं डाउनलोड करने की अनुमति देता है और सरल परियोजनाओं के लिए जीवन को आसान बनाने के लिए सरल स्क्रिप्ट निष्पादन प्रदान करता है। (आपको कार्यों को स्वचालित करने के लिए भविष्य में गुलप की तरह कुछ का उपयोग करने पर विचार करना चाहिए)।

{
  "name": "angular2-example",
  "version": "1.0.0",
  "scripts": {
    "start": "tsc && concurrently \"npm run tsc:w\" \"npm run lite\" ",
    "lite": "lite-server",
    "postinstall": "typings install",
    "tsc": "tsc",
    "tsc:w": "tsc -w",
    "typings": "typings"
  },
  "license": "ISC",
  "dependencies": {
    "@angular/common": "2.0.0-rc.4",
    "@angular/compiler": "2.0.0-rc.4",
    "@angular/core": "2.0.0-rc.4",
    "@angular/forms": "0.2.0",
    "@angular/http": "2.0.0-rc.4",
    "@angular/platform-browser": "2.0.0-rc.4",
    "@angular/platform-browser-dynamic": "2.0.0-rc.4",
    "@angular/router": "3.0.0-beta.1",
    "@angular/router-deprecated": "2.0.0-rc.2",
    "@angular/upgrade": "2.0.0-rc.4",
    "systemjs": "0.19.27",
    "core-js": "^2.4.0",
    "reflect-metadata": "^0.1.3",
    "rxjs": "5.0.0-beta.6",
    "zone.js": "^0.6.12",
    "angular2-in-memory-web-api": "0.0.14",
    "bootstrap": "^3.3.6"
  },
  "devDependencies": {
    "concurrently": "^2.0.0",
    "lite-server": "^2.2.0",
    "typescript": "^1.8.10",
    "typings":"^1.0.4"
  }
}
 

tsconfig.json - टाइपस्क्रिप्ट ट्रांसपिलर को कॉन्फ़िगर करता है।

{
  "compilerOptions": {
    "target": "es5",
    "module": "commonjs",
    "moduleResolution": "node",
    "sourceMap": true,
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "removeComments": false,
    "noImplicitAny": false
  }
}
 

typings.json - टाइपस्क्रिप्ट उन पुस्तकालयों को पहचानते हैं जिनका हम उपयोग कर रहे हैं।

{
  "globalDependencies": {
    "core-js": "registry:dt/core-js#0.0.0+20160602141332",
    "jasmine": "registry:dt/jasmine#2.2.0+20160621224255",
    "node": "registry:dt/node#6.0.0+20160621231320"
  }
}
 

systemjs.config.js - कॉन्फ़िगर करता SystemJS (आप भी उपयोग कर सकते हैं webpack )।

/**
 * System configuration for Angular 2 samples
 * Adjust as necessary for your application's needs.
 */
(function(global) {
  // map tells the System loader where to look for things
  var map = {
    'app':                        'app', // 'dist',
    '@angular':                   'node_modules/@angular',
    'angular2-in-memory-web-api': 'node_modules/angular2-in-memory-web-api',
    'rxjs':                       'node_modules/rxjs'
  };
  // packages tells the System loader how to load when no filename and/or no extension
  var packages = {
    'app':                        { main: 'main.js',  defaultExtension: 'js' },
    'rxjs':                       { defaultExtension: 'js' },
    'angular2-in-memory-web-api': { main: 'index.js', defaultExtension: 'js' },
  };
  var ngPackageNames = [
    'common',
    'compiler',
    'core',
    'forms',
    'http',
    'platform-browser',
    'platform-browser-dynamic',
    'router',
    'router-deprecated',
    'upgrade',
  ];
  // Individual files (~300 requests):
  function packIndex(pkgName) {
    packages['@angular/'+pkgName] = { main: 'index.js', defaultExtension: 'js' };
  }
  // Bundled (~40 requests):
  function packUmd(pkgName) {
    packages['@angular/'+pkgName] = { main: '/bundles/' + pkgName + '.umd.js', defaultExtension: 'js' };
  }
  // Most environments should use UMD; some (Karma) need the individual index files
  var setPackageConfig = System.packageWithIndex ? packIndex : packUmd;
  // Add package entries for angular packages
  ngPackageNames.forEach(setPackageConfig);
  var config = {
    map: map,
    packages: packages
  };
  System.config(config);
})(this);
 

चरण 3

टाइप करके निर्भरता स्थापित करते हैं

npm install
 

कंसोल / टर्मिनल में।

चरण 4

index.html angular2-example फ़ोल्डर के अंदर index.html बनाएँ।

<html>
  <head>
    <title>Angular2 example</title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 1. Load libraries -->
    <!-- Polyfill(s) for older browsers -->
    <script src="node_modules/core-js/client/shim.min.js"></script>
    <script src="node_modules/zone.js/dist/zone.js"></script>
    <script src="node_modules/reflect-metadata/Reflect.js"></script>
    <script src="node_modules/systemjs/dist/system.src.js"></script>
    <!-- 2. Configure SystemJS -->
    <script src="systemjs.config.js"></script>
    <script>
      System.import('app').catch(function(err){ console.error(err); });
    </script>
  </head>
  <!-- 3. Display the application -->
  <body>
    <my-app></my-app>
  </body>
</html>
 

आपका एप्लिकेशन my-app टैग के बीच प्रदान किया जाएगा।

हालांकि, कोणीय अभी भी नहीं जानता है कि क्या प्रस्तुत करना है। यह बताने के लिए कि, हम AppComponent को परिभाषित AppComponent

चरण 5

app नामक एक सबफ़ोल्डर बनाएं जहां हम उन घटकों और सेवाओं को परिभाषित कर सकते हैं जो हमारे ऐप को बनाते हैं। (इस मामले में, इसमें केवल AppComponent कोड और main.ts शामिल main.ts ।)

mkdir app
 

चरण 6

फाइल app/app.component.ts

import { Component } from '@angular/core';

@Component({
  selector: 'my-app',
  template: `
    <h1>{{title}}</h1>
    <ul>
        <li *ngFor="let message of messages">
            {{message}}
        </li>
    </ul>
  `
})
export class AppComponent { 
    title = "Angular2 example";
    messages = [
        "Hello World!",
        "Another string",
        "Another one"
    ];
}
 

क्या हो रहा है? सबसे पहले, हम @Component डेकोरेटर का आयात कर रहे हैं जिसका उपयोग हम Angular को HTML टैग और इस घटक के लिए टेम्पलेट देने के लिए करते हैं। फिर, हम title और messages चर के साथ वर्ग AppComponent बना रहे हैं जिसे हम टेम्पलेट में उपयोग कर सकते हैं।

अब आइए उस टेम्पलेट को देखें:

<h1>{{title}}</h1>
<ul>
    <li *ngFor="let message of messages">
        {{message}}
    </li>
</ul>
 

हम h1 टैग में title चर प्रदर्शित कर रहे हैं और फिर *ngFor निर्देश का उपयोग करके messages प्रत्येक तत्व को दर्शाने वाली एक सूची बना रहे हैं। सरणी में प्रत्येक तत्व के लिए, *ngFor एक message चर बनाता है, *ngFor उपयोग हम li तत्व के भीतर करते हैं। परिणाम होगा:

<h1>Angular 2 example</h1>
<ul>
    <li>Hello World!</li>
    <li>Another string</li>
    <li>Another one</li>
</ul>
 

चरण 7

अब हम एक main.ts फ़ाइल बनाते हैं, जो पहली फ़ाइल होगी जो कोणीय देखती है।

फ़ाइल app/main.ts बनाएँ।

import { bootstrap }    from '@angular/platform-browser-dynamic';
import { AppComponent } from './app.component';

bootstrap(AppComponent);
 

हम bootstrap फ़ंक्शन और AppComponent क्लास का आयात कर रहे हैं, फिर bootstrap का उपयोग करके कोणीय को बताएं कि रूट के रूप में किस घटक का उपयोग करना है।

चरण 8

यह आपके पहले ऐप को आग लगाने का समय है। प्रकार

npm start
 

आपके कंसोल / टर्मिनल में। इस से एक तैयार स्क्रिप्ट चलेंगे package.json कि शुरू होता है लाइट-सर्वर, एक ब्राउज़र विंडो में अपने अनुप्रयोग खोलता है, और घड़ी मोड में टाइपप्रति transpiler चलाता है (ताकि .ts फ़ाइलों transpiled किया जाएगा और ब्राउज़र परिवर्तनों को सहेजें ताज़ा होगी जब आप) ।

अब क्या?

आधिकारिक एंगुलर 2 गाइड और स्टैकऑवरफ्लो के प्रलेखन पर अन्य विषयों की जाँच करें

आप बाहरी टेम्पलेट्स, शैलियों का उपयोग करने के लिए AppComponent को भी संपादित कर सकते हैं या घटक चर जोड़ / संपादित कर सकते हैं। फ़ाइलों को सहेजने के तुरंत बाद आपको अपने परिवर्तनों को देखना चाहिए।

उस pesky कंपनी प्रॉक्सी के माध्यम से हो रही है

यदि आप XYZ MegaCorp पर अपने Windows वर्क कंप्यूटर पर Angular2 साइट चलाने का प्रयास कर रहे हैं, तो संभावना है कि आपको कंपनी प्रॉक्सी के माध्यम से समस्याएँ हो रही हैं।

कम से कम दो पैकेज प्रबंधक हैं जिन्हें प्रॉक्सी के माध्यम से प्राप्त करने की आवश्यकता है:

  1. NPM
  2. Typings

NPM के लिए आपको .npmrc फ़ाइल में निम्न पंक्तियाँ जोड़ने की आवश्यकता है:

proxy=http://[DOMAIN]%5C[USER]:[PASS]@[PROXY]:[PROXYPORT]/
https-proxy=http://[DOMAIN]%5C[USER]:[PASS]@[PROXY]:[PROXYPORT]/
 

टाइपिंग के लिए आपको .typingsrc फ़ाइल में निम्न पंक्तियों को जोड़ना होगा:

proxy=http://[DOMAIN]%5C[USER]:[PASS]@[PROXY]:[PROXYPORT]/
https-proxy=http://[DOMAIN]%5C[USER]:[PASS]@[PROXY]:[PROXYPORT]/
rejectUnauthorized=false
 

ये फ़ाइलें शायद अभी तक मौजूद नहीं हैं, इसलिए आप इन्हें रिक्त पाठ फ़ाइलों के रूप में बना सकते हैं। उन्हें प्रोजेक्ट रूट में जोड़ा जा सकता है ( package.json समान स्थान) या आप उन्हें %HOMEPATH% में रख सकते हैं और वे आपकी सभी परियोजनाओं के लिए उपलब्ध होंगे।

बिट जो स्पष्ट नहीं है और मुख्य कारण है कि लोगों को लगता है कि प्रॉक्सी सेटिंग्स काम नहीं कर रही हैं %5C जो कि डोमेन और उपयोगकर्ता नामों को अलग करने के लिए \ _ का URL एनकोड है। उस एक के लिए स्टीव रॉबर्ट्स को धन्यवाद: कॉर्पोरेट प्रॉक्सी के पीछे npm का उपयोग करना ।pac

कोणीय-क्ली के साथ कोणीय 2 स्थापित करें

यह उदाहरण कोणीय 2 का एक त्वरित सेटअप है और एक त्वरित उदाहरण परियोजना कैसे उत्पन्न करता है।

आवश्यक शर्तें:

एक टर्मिनल खोलें और एक-एक करके कमांड चलाएं:

npm install -g @angular/cli
 

या

yarn global add @angular/cli
 

पैकेज मैनेजर की अपनी पसंद के आधार पर।

पिछला कमांड विश्व स्तर पर @ कोणीय / cli स्थापित करता है, जो PATH के निष्पादन योग्य ng को जोड़ता है।

एक नई परियोजना की स्थापना के लिए

टर्मिनल के साथ एक फ़ोल्डर में नेविगेट करें जहां आप नई परियोजना स्थापित करना चाहते हैं।

आदेश चलाएँ:

ng new PROJECT_NAME
cd PROJECT_NAME
ng serve
 

यह वह है, अब आपके पास एक सरल उदाहरण परियोजना है जो कि कोणीय 2 के साथ बनाई गई है। अब आप टर्मिनल में प्रदर्शित लिंक पर नेविगेट कर सकते हैं और देख सकते हैं कि यह क्या चल रहा है।

मौजूदा प्रोजेक्ट में जोड़ने के लिए

अपने वर्तमान प्रोजेक्ट की जड़ में नेविगेट करें।

कमांड चलाएँ:

ng init
 

यह आपकी परियोजना में आवश्यक मचान जोड़ देगा। फ़ाइलों को वर्तमान निर्देशिका में बनाया जाएगा ताकि खाली निर्देशिका में इसे चलाना सुनिश्चित करें।

स्थानीय रूप से प्रोजेक्ट चला रहा है

ब्राउज़र में चलने के दौरान अपने एप्लिकेशन को देखने और उसके साथ सहभागिता करने के लिए, आपको अपने प्रोजेक्ट के लिए फ़ाइलों की मेजबानी करने वाला एक स्थानीय विकास सर्वर शुरू करना होगा।

ng serve
 

यदि सर्वर सफलतापूर्वक शुरू हुआ तो उसे एक पता प्रदर्शित करना चाहिए जिस पर सर्वर चल रहा है। आमतौर पर यह है:

http://localhost:4200
 

बॉक्स से बाहर यह स्थानीय विकास सर्वर हॉट मॉड्यूल रीलोडिंग के साथ जुड़ा हुआ है, इसलिए HTML, टाइपस्क्रिप्ट, या सीएसएस में कोई भी परिवर्तन, ब्राउज़र को स्वचालित रूप से पुनः लोड होने के लिए ट्रिगर करेगा (लेकिन यदि वांछित हो तो इसे अक्षम किया जा सकता है)।

घटक, निर्देश, पाइप और सेवाएँ उत्पन्न करना

ng generate <scaffold-type> <name> (या बस ng g <scaffold-type> <name> ) कमांड आपको स्वचालित रूप से कोणीय घटकों को उत्पन्न करने की अनुमति देता है:

# The command below will generate a component in the folder you are currently at
ng generate component my-generated-component
# Using the alias (same outcome as above)
ng g component my-generated-component
 

कई संभव प्रकार के मचानों कोणीय-क्ली उत्पन्न कर सकते हैं:

मचान प्रकार प्रयोग
मापांक ng g module my-new-module
अंग ng g component my-new-component
आदेश ng g directive my-new-directive
पाइप ng g pipe my-new-pipe
सेवा ng g service my-new-service
कक्षा ng g class my-new-class
इंटरफेस ng g interface my-new-interface
enum ng g enum my-new-enum

आप इसके पहले अक्षर से टाइप नाम को भी बदल सकते हैं। उदाहरण के लिए:

ng gm my-new-module एक नया मॉड्यूल उत्पन्न करने के लिए या एक घटक बनाने के लिए ng gc my-new-component

भवन / बंडलिंग

जब आप सभी अपने कोणीय 2 वेब ऐप का निर्माण कर लेते हैं और आप इसे Apache Tomcat जैसे वेब सर्वर पर स्थापित करना चाहते हैं, तो आपको केवल उत्पादन कमांड सेट के साथ या उसके बिना बिल्ड कमांड चलाने की आवश्यकता है। उत्पादन कोड को छोटा करेगा और उत्पादन सेटिंग के लिए अनुकूलित करेगा।

ng build
 

या

ng build --prod
 

उसके बाद प्रोजेक्ट्स रूट निर्देशिका में /dist फ़ोल्डर के लिए देखें, जिसमें बिल्ड शामिल है।

यदि आप एक छोटे उत्पादन बंडल के लाभों को पसंद करते हैं, तो आप अहेड-ऑफ-टाइम टेम्पलेट संकलन का भी उपयोग कर सकते हैं, जो अंतिम बिल्ड से टेम्पलेट कंपाइलर को हटा देता है:

ng build --prod --aot
 

इकाई का परीक्षण

कोणीय 2 अंतर्निहित इकाई परीक्षण प्रदान करता है, और कोणीय-क्ली द्वारा बनाई गई प्रत्येक वस्तु एक बुनियादी इकाई परीक्षण उत्पन्न करती है, जिसका विस्तार किया जा सकता है। इकाई परीक्षण चमेली का उपयोग करके लिखे गए हैं, और कर्म के माध्यम से निष्पादित किए जाते हैं। निम्नलिखित कमांड निष्पादित करने के लिए परीक्षण शुरू करने के लिए:

ng test
 

यह कमांड प्रोजेक्ट में सभी परीक्षणों को निष्पादित करेगा, और हर बार स्रोत फ़ाइल में परिवर्तन होने पर उन्हें फिर से निष्पादित करेगा, चाहे वह आवेदन से परीक्षण या कोड हो।

अधिक जानकारी के लिए यहां भी जाएं: कोणीय-क्लि गिथब पृष्ठ

NPM और NODE अपडेट के साथ विजुअल स्टूडियो को सिंक में रखना

चरण 1: Node.js के अपने डाउनलोड का पता लगाएँ, आम तौर पर यह C: / प्रोग्राम फ़ाइलों / नोडज के अंतर्गत स्थापित किया जाता है

चरण 2: विज़ुअल स्टूडियो खोलें और "टूल> विकल्प" पर नेविगेट करें

चरण 3: विकल्प विंडो में "प्रोजेक्ट और समाधान> बाहरी वेब उपकरण" पर जाएं

चरण 4: आपके साथ नई प्रविष्टि जोड़ें Node.js फ़ाइल स्थान (C: / प्रोग्राम फ़ाइलें / नोडज), सूची के शीर्ष पर अपना संदर्भ स्थानांतरित करने के लिए मेनू पर तीर बटन का उपयोग करें।

यहाँ छवि विवरण दर्ज करें

चरण 5: विज़ुअल स्टूडियोज़ को पुनः आरंभ करें और npm कमांड विंडो से, अपने प्रोजेक्ट के विरुद्ध एक npm इंस्टॉल रन करें

चलो कोणीय 4 में गोता लगाओ!

कोणीय 4 अब उपलब्ध है! दरअसल एंगुलर 2 के बाद से एंगुलर सेमर का उपयोग करता है, जिसके लिए ब्रेकिंग चेंजेज शुरू होने पर बड़ी संख्या में वृद्धि की आवश्यकता होती है। कोणीय टीम ने उन विशेषताओं को स्थगित कर दिया है जो ब्रेकिंग परिवर्तन का कारण बनती हैं, जो कोणीय 4 के साथ जारी किया जाएगा। कोणीय 3 को मुख्य मॉड्यूल के संस्करण संख्याओं को संरेखित करने में सक्षम होने के लिए छोड़ दिया गया था, क्योंकि राउटर में पहले से ही संस्करण 3 था।

कोणीय टीम के अनुसार, कोणीय 4 अनुप्रयोग पहले की तुलना में कम जगह लेने वाले और तेज़ होने वाले हैं। उन्होंने एनीमेशन पैकेज को @ कोणीय / कोर पैकेज से अलग कर दिया है। यदि कोई एनीमेशन पैकेज का उपयोग नहीं कर रहा है, तो कोड का अतिरिक्त स्थान उत्पादन में समाप्त नहीं होगा। टेम्पलेट बाइंडिंग सिंटैक्स अब समर्थन करता है यदि / अन्यथा स्टाइल सिंटैक्स। कोणीय 4 अब टाइपस्क्रिप्ट 2.1 और 2.2 के सबसे हाल के संस्करण के साथ संगत है। तो, एंगुलर 4 अधिक रोमांचक होने जा रहा है।

अब मैं आपको दिखाता हूँ कि अपने प्रोजेक्ट में Angular 4 का सेटअप कैसे करें।

आइए तीन अलग-अलग तरीकों से कोणीय सेटअप शुरू करें:

आप Angular-CLI (कमांड लाइन इंटरफेस) का उपयोग कर सकते हैं, यह आपके लिए सभी निर्भरताएं स्थापित करेगा।

  • आप Angular 2 से Angular 4 में माइग्रेट कर सकते हैं।

  • आप गितुब का उपयोग कर सकते हैं और Angular4-boilerplate क्लोन कर सकते हैं। (यह सबसे आसान है। एक)

  • कोणीय-सीएलआई (कमांड लाइन इंटरफ़ेस) का उपयोग कर कोणीय सेटअप।

इससे पहले कि आप कोणीय-सीएलआई का उपयोग शुरू करें, सुनिश्चित करें कि आपने अपने मशीन में नोड स्थापित किया है। यहां, मैं नोड v7.8.0 का उपयोग कर रहा हूं। अब, अपना टर्मिनल खोलें और कोणीय-सीएलआई के लिए निम्न कमांड टाइप करें।

npm install -g @angular/cli
 

या

yarn global add @angular/cli
 

आपके द्वारा उपयोग किए जाने वाले पैकेज मैनेजर के आधार पर।

चलो कोणीय-सीएलआई का उपयोग करके कोणीय 4 स्थापित करें।

ng new Angular4-boilerplate
 

सीडी Angular4-boilerplate हम सभी कोणीय 4 के लिए सेट कर रहे हैं। इसकी बहुत आसान और सरल विधि ।😌

कोणीय 2 से कोणीय 4 में स्थानांतरित करके कोणीय सेटअप

अब दूसरा दृष्टिकोण देखते हैं। मैं आपको दिखाता हूँ कि कोणीय 2 को कोणीय 4 में कैसे स्थानांतरित किया जाए। इसके लिए आपको किसी भी कोणीय 2 परियोजना को क्लोन करने की आवश्यकता है और अपने पैकेज में कोणीय 4 निर्भरता के साथ कोणीय 2 निर्भरता को अपडेट करें। निम्नानुसार:

"dependencies": {
    "@angular/animations": "^4.1.0",
    "@angular/common": "4.0.2",
    "@angular/compiler": "4.0.2",
    "@angular/core": "^4.0.1",
    "@angular/forms": "4.0.2",
    "@angular/http": "4.0.2",
    "@angular/material": "^2.0.0-beta.3",
    "@angular/platform-browser": "4.0.2",
    "@angular/platform-browser-dynamic": "4.0.2",
    "@angular/router": "4.0.2",
    "typescript": "2.2.2"
   }
 

ये कोणीय 4 के लिए मुख्य निर्भरताएं हैं। अब आप एनपीएम स्थापित कर सकते हैं और फिर एनपीएम एप्लिकेशन को चलाना शुरू कर सकते हैं। मेरे पैकेज के संदर्भ में।

गिटब प्रोजेक्ट से कोणीय सेटअप

इस चरण को शुरू करने से पहले सुनिश्चित करें कि आपने अपनी मशीन में स्थापित किया है। अपना टर्मिनल खोलें और नीचे कमांड का उपयोग करके कोणीय 4-बॉयलरप्लेट क्लोन करें:

git@github.com:CypherTree/angular4-boilerplate.git
 

फिर सभी निर्भरताएं स्थापित करें और इसे चलाएं।

npm install

npm start
 

और आपको कोणीय 4 सेटअप के साथ किया जाता है। सभी चरण बहुत सीधे हैं ताकि आप उनमें से किसी को भी चुन सकें।

निर्देशिका संरचना कोणीय 4-बॉयलरप्लेट

Angular4-boilerplate
-karma
-node_modules
-src
   -mocks
   -models
      -loginform.ts
      -index.ts
   -modules
      -app
        -app.component.ts
     -app.component.html
      -login
    -login.component.ts
    -login.component.html
    -login.component.css
      -widget
     -widget.component.ts
     -widget.component.html
     -widget.component.css
    ........    
   -services
       -login.service.ts
    -rest.service.ts
   -app.routing.module.ts
   -app.module.ts
   -bootstrap.ts
   -index.html
   -vendor.ts
-typings
-webpack
-package.json
-tsconfig.json
-tslint.json
-typings.json 
 

निर्देशिका संरचना के लिए बुनियादी समझ:

सभी कोड src फ़ोल्डर में रहता है।

मॉक फोल्डर मॉक डेटा के लिए है जिसका उपयोग परीक्षण उद्देश्य में किया जाता है।

मॉडल फ़ोल्डर में क्लास और इंटरफ़ेस होता है जिसका उपयोग घटक में किया जाता है।

मॉड्यूल फ़ोल्डर में ऐप, लॉगिन, विजेट आदि जैसे घटकों की सूची होती है। सभी घटकों में टाइपस्क्रिप्ट, HTML और सीएसएस फ़ाइल होती है। index.ts सभी वर्ग के निर्यात के लिए है।

सेवाओं के फ़ोल्डर में एप्लिकेशन में उपयोग की जाने वाली सेवाओं की सूची है। मैंने बाकी सेवा और अलग घटक सेवा को अलग कर दिया है। बाकी सेवा में अलग-अलग http तरीके होते हैं। लॉगिन कंपोनेंट और रेस्ट सर्विस के बीच लॉगिन सेवा मध्यस्थ की तरह काम करती है।

app.rout.ts फ़ाइल अनुप्रयोग के लिए सभी संभावित मार्गों का वर्णन करती है।

app.module.ts रूट घटक के रूप में ऐप मॉड्यूल का वर्णन करता है।

bootstrap.ts संपूर्ण अनुप्रयोग चलाएगा।

वेबपैक फ़ोल्डर में वेबपैक कॉन्फ़िगरेशन फ़ाइल है।

package.json फ़ाइल निर्भरता की सभी सूची के लिए है।

कर्म में इकाई परीक्षण के लिए कर्म विन्यास होता है।

नोड_मॉड्यूल में पैकेज बंडलों की सूची होती है।

लॉगिन घटक के साथ शुरू करते हैं। Login.component.html में

<form>Dreamfactory - Addressbook 2.0 
 <label>Email</label> <input id="email" form="" name="email" type="email" /> 
 <label>Password</label> <input id="password" form="" name="password" 
 type="password" /> 
 <button form="">Login</button>
</form>
 

Login.component.ts में

import { Component } from '@angular/core';
import { Router } from '@angular/router';
import { Form, FormGroup } from '@angular/forms';
import { LoginForm } from '../../models';
import { LoginService } from '../../services/login.service';

@Component({
    selector: 'login',
    template: require('./login.component.html'),
    styles: [require('./login.component.css')]
})
export class LoginComponent {

    constructor(private loginService: LoginService, private router: Router, form: LoginForm) { }

    getLogin(form: LoginForm): void {
      let username = form.email;
      let password = form.password;
      this.loginService.getAuthenticate(form).subscribe(() => {
          this.router.navigate(['/calender']);
      });
    }
}
 

हमें इस घटक को index.ts में निर्यात करने की आवश्यकता है।

export * from './login/login.component';
 

हमें app.routes.ts में लॉगिन के लिए मार्ग निर्धारित करने की आवश्यकता है

const appRoutes: Routes = [
   {
       path: 'login',
       component: LoginComponent
   },
   ........
   {
       path: '',
       pathMatch: 'full',
       redirectTo: '/login'
   }
];
 

रूट कंपोनेंट में, app.module.ts फाइल को आपको उस कंपोनेंट को इम्पोर्ट करने की जरूरत है।

.....
import { LoginComponent } from './modules';
......
@NgModule({
    bootstrap: [AppComponent],
    declarations: [
       LoginComponent
       .....
       .....
       ]
      ..... 
  })
  export class AppModule { }
 

और उसके बाद npm इंस्टॉल और npm स्टार्ट। हेयर यू गो! आप अपने स्थानीयहोस्ट में लॉगिन स्क्रीन की जांच कर सकते हैं। किसी भी कठिनाई के मामले में, आप कोणीय 4-बॉयलरप्लेट का उल्लेख कर सकते हैं।

मूल रूप से मैं कम बिल्डिंग पैकेज और अधिक तेजी से एंगुलर 4 एप्लिकेशन के साथ प्रतिक्रिया महसूस कर सकता हूं और हालांकि मुझे कोडिंग में एंगुलर 2 के समान सटीक रूप से मिला।