此貼文系列已在 NgateSystems.com 建立索引。您還可以在那裡找到超級有用的關鍵字搜尋工具。
最後評論:24 年 11 月
一、簡介
本系列先前介紹如何將 Svelte 框架與 Google 的 Firestore 資料庫用戶端 API 結合使用,快速、愉快地開發有用的資訊系統。然而遺憾的是,Post 3.3 揭示了 Firebase 原本出色的身份驗證系統如何不支援伺服器端 load() 和 actions() 函數中的 Firestore 活動,其中資料庫規則引用 auth 物件。
跳過 Firestore 授權規則不是一種選擇 - 如果沒有這些,您的資料庫將向任何可以從您的 Web 應用劫持 firebaseConfig 金鑰的人開放。這篇文章介紹了重新編寫 Svelte 伺服器端程式碼的方法,以便它在用戶端上運行,同時 Firestore 規則保持不變。
2. 重新設計「受損」的 load() 函數
並非所有 load() 函數都會受到 Firestore 規則的影響。那些引用 Firestore public 集合的容器仍將在伺服器端正常運作。客戶端 API 仍然可以在 page.server.js 檔案中使用 - 如果要求使用受驗證保護的集合,它就無法運作。
如果您的 load() 函數處理公用文件,而您只想避免伺服器端偵錯,您可以考慮將 load() 函數移至 page.js 檔案中。這與 page.server.js 檔案完全相同 - Svelte 仍會在載入時自動執行函數。但現在這種情況發生在客戶端,可以在瀏覽器中進行偵錯。有關詳細信息,請參閱加載數據中的 Svelte 文件
但是,「受損」的 load() 函數(通常使用 Firestore 規則來確保使用者只能存取自己的資料)必須重新定位到客戶端程式碼中。通常,這將重新設計為 <script> 中的新的、適當命名的函數。其關聯的 page.svelte 檔案的部分。 </script>
但現在您必須找到一種方法來在頁面初始化時自動啟動重新定位的 load() 函數 - 您不再受益於 Svelte 的原生 load() 函數的內建安排。問題是您重新定位的函數是非同步的,因此無法直接從 page.svelte 檔案的 <script> 啟動。部分。這個問題可以透過使用 Svelte 的 onMount 實用程式來解決。 </script>
“OnMount”是一個 Svelte 生命週期“鉤子”,在啟動 Web 應用程式頁面時自動運行。在 onMount() 內,您現在可以安全地等待重新定位的 load() 函數 - 您可能還記得之前在註銷函數中遇到過它。您可以在 Svelte Lifecycle Hooks 中找到描述。
3. 重新設計「受損」的 actions() 函數
在這種情況下,沒有選擇。受損的 actions() 函數必須重新定位到 <script> 中。父 page.svelte 檔案的部分。此處的表單提交按鈕必須重新設計,以透過 on:click 安排引用重新定位的函數來「觸發」操作。 </script>
4. 範例:產品顯示頁面的規則友善版本
在以下程式碼範例中,新的 products-display-rf 路由顯示舊的「Magical Products」productNumbers 清單。這裡使用的 load() 沒有受到影響,但它的程式碼仍然被移到 page.js 檔案中,讓您確認可以在瀏覽器中偵錯它。唯一的其他變化是:
- 程式碼現在包含在按一下「神奇產品」清單中的產品項目時顯示 ProductDetails 欄位的擴充功能。
- firebase-config 現在從上一篇文章介紹的 lib 檔案匯入
將此程式碼複製到「-rf」後綴資料夾中的新檔案中。但在執行此操作時請務必小心 - 在 VSCode 狹窄的資料夾層次結構中處理大量令人困惑的頁面檔案需要高度集中註意力。完成後,執行開發伺服器並在 http://localhost:5173/products-display-rf 位址測試新頁面。
「產品顯示」頁面看起來應該與以前完全相同,但是當您點擊時,「產品詳細資料」頁面現在應該顯示動態產生的內容。
5. 範例:產品維護頁面的規則友善版本
產品維護頁面的客戶端版本中的事情更加有趣。
由於您的產品集合的 Firebase 規則現在會引用身份驗證(因此要求潛在用戶「登入」),因此新增產品文件的 actions() 函數會受到損害。因此必須將其從 page.server.js 檔案中移出並重新定位到父 page.svelte 檔案中。
這裡,函數被重新命名為handleSubmit(),並由
以上是NgSysV.A Serious Svelte InfoSys:規則友善的版本的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript核心數據類型在瀏覽器和Node.js中一致,但處理方式和額外類型有所不同。 1)全局對像在瀏覽器中為window,在Node.js中為global。 2)Node.js獨有Buffer對象,用於處理二進制數據。 3)性能和時間處理在兩者間也有差異,需根據環境調整代碼。

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

SublimeText3漢化版
中文版,非常好用

Dreamweaver CS6
視覺化網頁開發工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)