<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                # 如何使用 Java EE 和 Angular 構建單頁應用程序 > 原文: [https://javatutorial.net/how-to-build-single-page-application-with-java-ee-and-angular](https://javatutorial.net/how-to-build-single-page-application-with-java-ee-and-angular) 本文介紹如何使用 Angular 和 Java EE 構建自己的單頁應用程序 網絡世界一直令人眼花亂。 如今,可見網絡上有超過 18 億個頁面,其中大多數頁面提供了某種想法,業務,原因或互聯網上您擁有的任何內容。 每天都有越來越多的人對 Web 感興趣,而第二者正在創建內容。 然后,您可以了解為什么 Web 開發是目前最繁榮的工作之一。 該技術本身正在迅速發展,以滿足用戶的需求,并通過更好的沉浸式用戶體驗超越了它。 這種追求促使 SPA 等技術成為行業領先的技術。 他們的增長驚人,用戶似乎對新的升級感到非常滿意。 今天,我們將使用 Angular 和 Java EE 構建自己的單頁應用程序,為您自己的實現奠定基礎。 ![](https://img.kancloud.cn/3c/a0/3ca0b4f1aeb3b2df15d6c4f93323fdae_700x443.jpg) [圖像源](https://koukia.ca/going-single-page-app-or-traditional-web-app-cedb10041b50) ## 什么是 SPA? 單頁應用程序是一種設計模式,特別是一種確定程序流程的架構設計模式。 這樣做的想法是一次加載所有數據和元素,以防止在用戶使用頁面時刷新頁面。 例如,您可能已經注意到,首次加載 Gmail 后,它甚至可以脫機運行,而且運行速度也很快。 Gmail,Facebook,GitHub 和許多其他應用程序使用 SPA 來提供自然的 UX,以保持不受干擾的用法。 如今,這種想法已逐漸發展為一種設計方向,PWA 則采用了相同的概念,即提供幾乎自然的離線體驗。 ![Traditional page lifecycle vs. SPA lifecycle](https://img.kancloud.cn/25/0b/250b241b4ffb325f3e75964006664bf8_550x609.jpg) 傳統頁面生命周期與 SPA 生命周期 [圖像源](https://msdn.microsoft.com/en-us/magazine/dn463786.aspx) 實際上,SPA 的許多優點使其成為開發人員的青睞選擇。 例如,使用 SPA,隨著編寫服務器渲染代碼的需求隨著 SPA 的消失,開發過程變得越來越容易。 SPA 應用程序直接呈現到瀏覽器。 將移動應用程序與您的應用程序集成起來比較容易,因為您可以使用相同的網絡后端。 當然,大多數資源(如 HTML,CSS 和腳本)在應用程序的生命周期內僅加載一次,這一事實使應用程序變得更快,因為僅在需要時來回傳輸數據。 這全都歸功于 JavaScript 框架為我們完成了大部分繁重的工作。 使用 SPA 確實有一些弊端,例如 SEO 變得有些難以管理,但是在完成應用程序后,我們將討論如何解決該問題。 今天要使用的框架是著名的 Angular。 ## 為什么要 Angular? 好吧,您可能想知道為什么每個人都對 Angular 狂熱。 畢竟,目前的排名表明 Angular 是 JS 框架王國的統治者。 它是迄今為止使用最廣泛的框架,并且擁有最大的社區之一和大量文檔。 Angular 允許我們使用雙向數據綁定來構建動態 Web 應用程序。 在電子商務網站上瀏覽時,您不想每次簽出新產品或同一產品的其他版本時都重新加載頁面,而 Angular 允許您這樣做。 它也很容易構建和調試,因此使用 Angular 可以使測試變得更加容易,這是 Web 開發的核心步驟。 為此,互聯網上有許多 [Angular 教程](https://hackr.io/tutorials/learn-angular)和課程,可以從中找到基本信息。 ## 為什么選擇 Java EE? Java 企業版是健壯的技術和 API 的分組集合,用于企業級別,以構建可滿足關鍵業務需求和約束的可伸縮,事務性和分布式應用程序。 它旨在使 Java 開發保持最新狀態,以滿足當今應用程序的標準。 [Java EE](https://javatutorial.net/category/java-ee) 帶有大量的規范,可以滿足您的需求。 這就是為什么 Java EE 是理想的開始我們創建第一個 SPA 的旅程的原因。 我們將使用 Java 為 Angular 前端創建 REST 服務以供使用。 因此,讓我們開始吧。 我們將設計一個簡單的應用程序,在表格中顯示演員姓名及其著名的昵稱。 請注意,為了避免將本文變成 Java/Angular 課程,并且將重點放在 SPA 開發上,將省略一些代碼。 ## 后端 Java 持久化 API 將使我們能夠管理和操縱應用程序和服務器之間的數據。 通過使用`@Entity`注解,我們可以將對象類建模為數據庫內部的數據庫實體。 您可能已經猜到`@ID`為此關系設置了主鍵,這是事實。 我們可以使用`@table`表示法來指定某些表屬性,例如唯一性約束(數據成員必須是唯一的,即候選鍵)和表名。 `@namedqueries`允許我們準備某些查詢以用于該關系。 然后,我們繼續使用構造函數,setter 和 getter 構建基本類。 ![Actor Entity class](https://img.kancloud.cn/ba/17/ba17f7db4e5140aa03f5cf7f5cb5f773_908x838.jpg) 演員實體類 我們首先創建 JPA 所需的`persistence.xml`文件,它看起來像這樣。 `javax.persistence.schema-generation`不僅使我們能夠以自然的方式運行 SQL,而且還可以連接到數據源(如果我們尚未連接到 SQL 源)。 因此,這樣做可以省去您的麻煩。 ![persistence.xml file](https://img.kancloud.cn/6b/53/6b53702e6838ec769a0166ac650d07a4_1016x346.jpg) `persistence.xml`文件 這里要做的一件事是創建`Resources`類,以將該數據庫公開為資源類。`@Get`表示法定義 HTTP Get 謂詞行為,并以一種非常不錯的方式格式化 JSON 響應。 ![Web-service class](https://img.kancloud.cn/c0/56/c056ec15b5c4c3db8112229a10a02460_894x848.jpg) 網絡服務類 ## 前端 現在該跳到我們的前端了。 我們將分兩個步驟進行操作,首先是 HTML 文件,因為 Angular 擴展了典型的 HTML,并允許我們按照 MVC 設計,使用 Javascript 變量向組件添加自定義數據綁定。 HTML 文件中沒有太多代碼,這使 Angular 相當有效。 Angular 擁有我們將在此處使用的網格組件,Bootstrap 還提供了外觀漂亮的組件集,可供我們使用。 ![Angular HTML file](https://img.kancloud.cn/aa/3b/aa3ba63418cf1b6c48a61b6b4547e97b_906x299.jpg) Angular HTML 文件 現在剩下的唯一事情就是制作一個 Javascript 文件,將所有內容整合在一起。 Javascript 文件將定義客戶端行為,并使用我們之前創建的 REST 服務發出 HTTP 請求。 這是程序中真正魔術的體現。 ![Angular code](https://img.kancloud.cn/c9/46/c9462f1ea8a128fe63c1af78312074e7_807x656.jpg) Angular 代碼 ## Angular SEO 優化 SPA 的核心問題之一是 SEO 優化,這對于某些 SPA 的成功至關重要。 Google 在抓取 Javascript 內容時遇到了問題,盡管他們正在努力,但它還不完全兼容 JS。 有多種方法可以解決此問題,可以手動或使用自定義服務。 這個想法是從您的應用程序創建一個 HTML 快照以直接提供給搜尋器,而不是希望它可以正確理解和索引您的 Angular 代碼。 如果您無法手動完成任務,也可以減輕壓力,則可以使用預渲染平臺來完成任務。 您還可以執行一些輔助操作,例如獲取有意義的 URL 名稱而不是隨機生成的 URL 名稱。 維護用戶友好的 URL 會反過來給您的用戶和應用程序增加很多。 您應該使用一些工具來監視 SPA 的性能,并監視所有需要的更改。 ## 總結 回顧一下,我們首先通過 Java 持久化 API 構建數據庫,然后創建了 Java 資源類以作為 REST 服務訪問數據庫,盡管這里我們僅演示了 GET 方法。 在完成了后端之后,我們繼續進行前端,我們創建了 HTML 組件文件,這要歸功于 AngularJS,它非常簡單明了。 最后,Javascript 文件將所有內容組合在一起,為應用程序注入了生命。 Angular 是一個非常強大的框架,它允許您僅用幾行代碼即可創建完全不同的 UX,這非常令人驚訝。 能夠通過 Java RESTful 后端擴展 JS 前端可以增加更多的表格,并提高您作為開發人員的技能。 Angular 越來越流行,誰知道它何時會成為開發標準,與此同時,它是 SPA 領域的第一大統治框架。 請記住,傳統網頁也有其優點,因此您需要事先確定要遵循的模式。 例如,MPA 更安全,因為它們涉及的客戶端腳本更少,并且正如我們之前提到的,它們更易于針對 SEO 進行優化。 在開發中總會有這種折衷,您必須選擇一個選擇。 但是,SPA 將繼續是一個非常強大的選擇。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看