Skip to content

Latest commit

 

History

History
124 lines (109 loc) · 6.55 KB

README-RO.md

File metadata and controls

124 lines (109 loc) · 6.55 KB

Angular RU Universal Starter

Angular-RU Angular-RU Universal Angular-RO JS-RO Build Status

Repozitoriul Angular CLI și Angular Universal

Traduceri:

Resurse:

Planuri:

  • Angular 5
  • document is not defined și window is not defined - aici
  • Angular Material2 UI componente - branch aparte
  • Primeng UI компоненты - branch aparte
  • importăm modulele în dependență de platformă (MockServerBrowserModule)
  • comunicăm cu api pe server TransferHttp
  • folosim Cookies pe server UniversalStorage
  • folosim ngx-meta pentru SEO (title, meta tags, and Open Graph tags for social sharing).
  • folosim ngx-translate pentru i18n
  • folosim ORIGIN_URL - pentru drumuri absolute
  • @angular/service-worker(ng add @angular/pwa --project universal-demo)
  • Ionic - e nevoie să creăm versiunea web, până când avem probleme branch aparte

Cum să pornim?

  • yarn sau npm install
  • yarn start sau npm run start - pentru rendering pe client
  • yarn ssr sau npm run ssr - pentru rendering pe server
  • yarn build:universal sau npm run build:universal - pentru production
  • yarn server sau npm run server - pentru a porni serverul
  • yarn build:prerender sau npm run build:prerender - pentru a genera statica pe static.paths.ts
  • pentru a porni regimul watch, în ssr folosiți:
    • npm run ssr:cw - înpachetăm pentru client
    • npm run ssr:sw - înpachetăm pentru server
    • npm run ssr:webpack - înpachetăm server.js
    • npm run ssr:server - server cu watch

Cum să folosesc repozitoriul în proiectul meu?

Pentru a adăuga ssr în proiectul dumneavoastră e nevoie de următoarele fișiere:

  • .angular-cli.json
  • server.ts
  • prerender.ts
  • webpack.config.js
  • main.server.ts
  • main.browser.ts
  • shared/*
  • forStorage/*
  • environments/*
  • app.browser.module.ts
  • app.server.module.ts

Linkuri

Exemplu oficial în engleză: https://github.com/angular/universal-starter Module folosite pentru universal:

Caracteristici (Important)

  • modulul pentru TransferHttp folosește import { TransferState } from '@angular/platform-browser'; și e nevoie de el pentru a realiza interogările la rest api pe server și pentru a evita dublarea interogărilor (pe client). Uitați-vă la home.component.ts (așteptați 3 secunde)
this.http.get('https://reqres.in/api/users?delay=3').subscribe(result => {
    this.result = result;
});
  • export const AppRoutes = RouterModule.forRoot(routes, { initialNavigation: 'enabled' }); - ca pagina să nu clipească!

  • pentru a lucra cu cookie e scris AppStorage, care cu ajutorul DI ne permite să facem realizare pentru server și browser. Uitați-vă la server.storage.ts și browser.storage.ts pentru a vedea realizările. În server.ts este

providers: [
    {
        provide: REQUEST, useValue: (req)
    },
    {
        provide: RESPONSE, useValue: (res)
    }
]

pentru a lucra cu REQUEST și RESPONSE prin DI - asta-i necesar pentru a lucra cu UniversalStorage când folosim cookies.

  • webpack.config.js e scris doar ca să strângă fișierul server.ts și server.js, pentru că angular-cli are o eroare la 3d dependențele.
  • pentru a rezolva o mare parte din probleme se folosește următorul cod server.ts

Rezolvarea problemei cu variabilele globale, inclusiv document is not defined și window is not defined

const domino = require('domino');
const fs = require('fs');
const path = require('path');
const template = fs.readFileSync(path.join(__dirname, '.', 'dist', 'index.html')).toString();
const win = domino.createWindow(template);
const files = fs.readdirSync(`${process.cwd()}/dist-server`);
const styleFiles = files.filter(file => file.startsWith('styles'));
const hashStyle = styleFiles[0].split('.')[1];
const style = fs.readFileSync(path.join(__dirname, '.', 'dist-server', `styles.${hashStyle}.bundle.css`)).toString();

global['window'] = win;
Object.defineProperty(win.document.body.style, 'transform', {
  value: () => {
    return {
      enumerable: true,
      configurable: true
    };
  },
});
global['document'] = win.document;
global['CSS'] = style;
// global['XMLHttpRequest'] = require('xmlhttprequest').XMLHttpRequest;
global['Prism'] = null;
global['navigator'] = req['headers']['user-agent'];

asta ne permite să excludem o parte din problemele apărute cu undefined.