Angular Universal服務(wù)器端渲染避免 window is not defined錯誤消息
引言
盡管 Universal 項目的目標(biāo)是能夠在服務(wù)器上無縫呈現(xiàn) Angular 應(yīng)用程序,但開發(fā)人員還是應(yīng)該考慮一些注意事項。
首先,服務(wù)器和瀏覽器環(huán)境之間存在明顯差異。 在服務(wù)器上呈現(xiàn)時,您的應(yīng)用程序處于 ephemeral
或者 Snapshot 狀態(tài)。
應(yīng)用程序完全呈現(xiàn)一次,返回生成的 HTML,其余應(yīng)用程序狀態(tài)在下一次呈現(xiàn)之前被銷毀。
其次,服務(wù)器環(huán)境本質(zhì)上不具有與瀏覽器相同的功能(并且具有一些瀏覽器同樣不具有的功能)。 例如,服務(wù)器沒有任何cookies 的概念。
固然開發(fā)人員可以 polyfill 來一定程度上規(guī)避這個問題,但是沒有完美的解決方案。
另請注意 SSR 的目標(biāo):改進應(yīng)用程序的初始渲染時間。 這意味著應(yīng)避免或充分防范任何可能降低此初始渲染中應(yīng)用程序速度的情況出現(xiàn)。
一些 啟用 SSR 后的常見錯誤:
window is not defined
使用 Angular Universal 時最常見的問題之一是服務(wù)器環(huán)境中缺少瀏覽器全局變量。 這是因為 Universal 項目使用 domino 作為服務(wù)器 DOM 呈現(xiàn)引擎。 因此,服務(wù)器上不會存在或不支持某些功能。 這包括窗口和文檔全局對象、cookie、某些 HTML 元素(如畫布)和其他幾個。 Domino 代表節(jié)點中的 DOM.
解決這個錯誤的一些思路
通常,需要的全局變量可以通過 Angular 平臺通過依賴注入 (DI) 獲得。
例如,全局文檔可通過 DOCUMENT 令牌獲得。 此外,通過 DOCUMENT 對象可以獲得 window 和 location 的非常原始的版本。
例如:
示例代碼如下:
import { Injectable, Inject } from '@angular/core'; import { DOCUMENT } from '@angular/common'; @Injectable() export class ExampleService { constructor(@Inject(DOCUMENT) private _doc: Document) {} getWindow(): Window | null { return this._doc.defaultView; } getLocation(): Location { return this._doc.location; } createElement(tag: string): HTMLElement { return this._doc.createElement(tag); } }
以上就是Angular Universal服務(wù)器端渲染避免 window is not defined錯誤消息的詳細(xì)內(nèi)容,更多關(guān)于Angular Universal服務(wù)器端渲染的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
淺談angularJs函數(shù)的使用方法(大小寫轉(zhuǎn)換,拷貝,擴充對象)
今天小編就為大家分享一篇淺談angularJs函數(shù)的使用方法(大小寫轉(zhuǎn)換,拷貝,擴充對象),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10AngularJS基礎(chǔ) ng-include 指令簡單示例
本文主要介紹AngularJS ng-include 指令,這里對ng-include的基本知識做了整理,并附有代碼實例,有需要的朋友可以參考下2016-08-08anime.js 實現(xiàn)帶有描邊動畫效果的復(fù)選框(推薦)
anime.js是一個靈活的輕型JavaScript動畫庫。這篇文章主要介紹了anime.js 實現(xiàn)帶有描邊動畫效果的復(fù)選框 ,需要的朋友可以參考下2017-12-12Angular.js?實現(xiàn)帶手柄自由調(diào)整頁面大小的功能
這篇文章主要介紹了Angular.js?實現(xiàn)帶手柄自由調(diào)整頁面大小的功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-12-12