Angular 使用 @toolkit/universal 实现服务端渲染

Angular 使用 @toolkit/universal 实现服务端渲染

SPA 的缺陷 — SEO

基本上所有现在大行其道的单页应用都存在这个问题,它们只在客户端运行和渲染,也许你会说:“单页明明就是这样设计的,这是优点而不是缺陷!”,
当然,你说的完全正确!现在的问题是你的应用“只在”客户端渲染和运行。

爬虫是怎样去爬取网页的?

问题在于搜索引擎的 机器人/爬虫 的工作类似于CURL命令。为什么呢?启动浏览器和执行JavaScript脚本是一项非常昂贵的操作,当你需要搜索成千上万网页时,没有时间和资源去做这样昂贵的操作。

让我们来创建一个简单的 angular 应用程序,看看爬虫是如何来爬去它的:

ng new myApp
cd myApp
ng serve

现在在另一个终端窗口中执行CURL命令并查看输出:

$ curl localhost:4200
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>MyApp</title>
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
</head>
<body>
<app-root></app-root>
<script type="text/javascript" src="runtime.js"></script><script type="text/javascript" src="polyfills.js"></script><script type="text/javascript" src="styles.js"></script><script type="text/javascript" src="vendor.js"></script><script type="text/javascript" src="main.js"></script></body>
</html>

你看到问题了吗?我们在 Body 里面得到了什么? 什么有用的信息都没有,只有App Bootstrap node 和一些JavaScript。我们怎样解决呢?

服务端渲染 (Angular Universal)

这个解决方案就是 Angular Universal,NodeJS的一种 Angular 扩展,它在服务器上启动应用程序,并根据收入请求生成完整的 HTML 响应。现在,从用户请求到渲染和交互的Web应用程序的流程看起来如下:
1. 用户请求网页
2. 请求发送到服务端
3. NodeJS生成 HTML 并将其发送到浏览器
4. 浏览器从HTML呈现视图,并立即将其显示给用户,同时执行JavaScript。
5. 当JavaScript完成应用程序的引导时,它用 Angular 应用程序更改HTML渲染视图。
6. 用户看到完全可交互的 Angular 应用

好的,现在这个理论我们已经了解了,现在我们用一个简单的例子来练习一下吧。

@ng-toolkit/universal — 一行命令添加 Angular Universal 在任何 Angular 项目中

键入一个简单命令:

ng add @ng-toolkit/universal

boom! 你已经导入它了! 全部的导入步骤你已经做完了!
让我们来运行这个应用:

npm run build:prod
npm run server

并在单独的终端窗口检查一下效果:

$ curl localhost:8080
<!DOCTYPE html><html lang="en"><head>
<meta charset="utf-8">
<title>MyApp</title>
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
<link rel="stylesheet" href="styles.34c57ab7888ec1573f9c.css"><style ng-transition="app-root"></style></head>
<body>
<app-root _nghost-c0="" ng-version="6.0.3"><div _ngcontent-c0="" style="text-align:center"><h1 _ngcontent-c0=""> Welcome to app! </h1><img _ngcontent-c0="" alt="Angular Logo" src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNTAgMjUwIj4KICAgIDxwYXRoIGZpbGw9IiNERDAwMzEiIGQ9Ik0xMjUgMzBMMzEuOSA2My4ybDE0LjIgMTIzLjFMMTI1IDIzMGw3OC45LTQzLjcgMTQuMi0xMjMuMXoiIC8+CiAgICA8cGF0aCBmaWxsPSIjQzMwMDJGIiBkPSJNMTI1IDMwdjIyLjItLjFWMjMwbDc4LjktNDMuNyAxNC4yLTEyMy4xTDEyNSAzMHoiIC8+CiAgICA8cGF0aCAgZmlsbD0iI0ZGRkZGRiIgZD0iTTEyNSA1Mi4xTDY2LjggMTgyLjZoMjEuN2wxMS43LTI5LjJoNDkuNGwxMS43IDI5LjJIMTgzTDEyNSA1Mi4xem0xNyA4My4zaC0zNGwxNy00MC45IDE3IDQwLjl6IiAvPgogIDwvc3ZnPg==" width="300"></div><h2 _ngcontent-c0="">Here are some links to help you start: </h2><ul _ngcontent-c0=""><li _ngcontent-c0=""><h2 _ngcontent-c0=""><a _ngcontent-c0="" href="https://angular.io/tutorial" rel="noopener" target="_blank">Tour of Heroes</a></h2></li><li _ngcontent-c0=""><h2 _ngcontent-c0=""><a _ngcontent-c0="" href="https://github.com/angular/angular-cli/wiki" rel="noopener" target="_blank">CLI Documentation</a></h2></li><li _ngcontent-c0=""><h2 _ngcontent-c0=""><a _ngcontent-c0="" href="https://blog.angular.io/" rel="noopener" target="_blank">Angular blog</a></h2></li></ul></app-root>
<script type="text/javascript" src="runtime.a66f828dca56eeb90e02.js"></script><script type="text/javascript" src="polyfills.2f4a59095805af02bd79.js"></script><script type="text/javascript" src="main.178573f0f1b826344a91.js"></script>
<script id="app-root-state" type="application/json">{}</script></body></html>

这就是我们想要的不是吗?现在搜索引擎和爬虫可以看到你的应用程序有一些内容!这还不是全部。你可以向前走,用另一个伟大的工具@ng-toolkit:

ng add @ng-toolkit/serverless

而且,服务器端渲染的应用程序已经准备好部署在 AWS Lambda 上了。

Thanks for reading!

原文地址(可能需要科学上网)

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值