Angular是一个单页面应用程序(SPA)框架,它的路由系统使得应用程序的内容能够基于URL动态更新,这也就意味着应用程序的某些内容可能只能通过JavaScript代码生成,也就是说不会在源代码中出现。这可能会影响搜索引擎爬虫的访问和理解。
为了解决这个问题,我们可以使用Angular的服务端渲染(SSR),这可以使服务端在渲染HTML之前对Angular组件进行预编译,并在HTML中生成结构化标记,这些标记就能够被Googlebot看到和索引了。
以下是一个使用Angular Universal实现服务端渲染的示例:
import { enableProdMode } from '@angular/core';
import { renderModule, renderModuleFactory } from '@angular/platform-server';
import { AppServerModule } from './app/app.server.module';
import { ngExpressEngine } from '@nguniversal/express-engine';
import * as express from 'express';
const app = express();
app.engine('html', ngExpressEngine({
bootstrap: AppServerModule
}));
app.set('view engine', 'html');
app.set('views', 'dist');
app.use(express.static('dist'));
app.get('/*', (req, res) => {
res.render('index', {
req,
res,
providers: [
{provide: 'SERVER_URL', useValue: `${req.protocol}://${req.headers.host}`}
]
});
});
const server = app.listen(4000, () => {
console.log(`Server listening on http://localhost:${server.address().port}`);
});
以上代码实现了一个简单的Express.js服务器,使用Angular Universal进行服务端渲染,当访问应用程序的任何URL时,都会将请求传递到Angular Universal的ngExpressEngine,并使用预编译的模块AppServerModule
生成HTML响应。最后,将响应发送