Repozitoriul Angular CLI și Angular Universal
Traduceri:
Resurse:
- chat public rusesc https://t.me/angular_universal_ru
- chat public Angular românesc https://t.me/angular_ro
- https://ssr.angular.su/ - rendering pe server master
- https://csr.angular.su/ - rendering pe client master
- Angular 5
-
document is not defined
șiwindow 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
yarn
saunpm install
yarn start
saunpm run start
- pentru rendering pe clientyarn ssr
saunpm run ssr
- pentru rendering pe serveryarn build:universal
saunpm run build:universal
- pentru productionyarn server
saunpm run server
- pentru a porni serverulyarn build:prerender
saunpm run build:prerender
- pentru a genera statica pestatic.paths.ts
- pentru a porni regimul watch, în ssr folosiți:
npm run ssr:cw
- înpachetăm pentru clientnpm run ssr:sw
- înpachetăm pentru servernpm run ssr:webpack
- înpachetămserver.js
npm run ssr:server
- server cu watch
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
Exemplu oficial în engleză: https://github.com/angular/universal-starter Module folosite pentru universal:
- https://github.com/angular/universal/tree/master/modules/aspnetcore-engine - motorul pentru .net core
- https://github.com/angular/universal/tree/master/modules/common - TransferHttpCacheModule, la acest moment nu-l folosesc, dar dacă știți pentru ce și unde se poate de-l pus - deschideți o issue sau pull request
- https://github.com/angular/universal/tree/master/modules/express-engine - Express Engine pentru a porni renderingul pe node, folosim în repozitoriul nostru. Fiți atenți, versiunea acutală nu mai mică de 5.0.0-beta.5
- https://github.com/angular/universal/tree/master/modules/hapi-engine - Hapi Engine un motor alternativă. În exemplu nu folosim, în principui nu-i mare diferența în conectare față de express-engine
- https://github.com/angular/universal/tree/master/modules/module-map-ngfactory-loader - modul pentru LazyLoading - e ceva folositor. Fiți atenți, versiunea actuală nu mai mică de 5.0.0-beta.5
- 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ă lahome.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ă laserver.storage.ts
șibrowser.storage.ts
pentru a vedea realizările. Înserver.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
.