angluarjs2項目生成內容合併到asp.net mvc4項目中一起發佈

来源:http://www.cnblogs.com/cnlizhipeng/archive/2016/12/31/angular2_mvc4.html
-Advertisement-
Play Games

應用場景 應用場景 angular2(下文中標註位NG2)項目和.net mvc項目分別開發,前期採用跨域訪問進行並行開發,後期只需要將NG2項目的生產版本合併到.net項目。 NG2項目概述 NG2項目概述 ng2項目採用的是angular-cli搭建的框架。 使用type script、rxjs ...


  • 應用場景

angular2(下文中標註位NG2)項目和.net mvc項目分別開發,前期採用跨域訪問進行並行開發,後期只需要將NG2項目的生產版本合併到.net項目。

  • NG2項目概述

  1. ng2項目採用的是angular-cli搭建的框架。

  2. 使用type script、rxjs等內容開發。

  • .net mvc 項目概述:

  1. 前期開發階段,去除了驗證內容,並支持跨域(這裡沒有使用api)。

  2. 後期需要與ng2的發佈內容進行整合。

  • 具體步驟(只說明.net mvc中的操作內容)

  • 路由內容設置
  • //防止用戶刷新路由指向錯誤
                routes.MapRoute(
                   name: "ngdefault",
                   url: "content/dist/{*.}",
                   defaults: new { controller = "Home", action = "Index" }
               );
                //原NG2開發框架中的調用內容
                routes.MapRoute(
                    name: "MyRoute",
                    url: "api/{controller}/{action}"
                );
                //正常的頁面請求
                routes.MapRoute(
                    name: "Default",
                    url: "{controller}/{action}/{*pathInfo}",
                    defaults: new { controller = "Home", action = "Index"}
                );
  • 頁面設置(以下為我的Home控制器Index對應的頁面內容)

  • @{
        Layout = null;
    }
    
    <!DOCTYPE html>
    
    <html>
    <head>
        <meta name="viewport" content="width=device-width" />
        <title>Index</title>
        <base href="/content/dist/">
    </head>
    <body>
        <app-root></app-root>
      @* 以下內容要根據你的NG2項目的生成內容來設置,具體請參照你的NG2項目引導頁面的內容。 *@ <script type="text/javascript" src="~/content/dist/inline.js"></script> <script type="text/javascript" src="~/content/dist/styles.41c78f28e60ca8b5fd69.bundle.js"></script> <script type="text/javascript" src="~/content/dist/scripts.bc1943ee0f025606a729.bundle.js"></script> <script type="text/javascript" src="~/content/dist/main.2ad5580a0f71e9dcee3e.bundle.js"></script> </body> </html>
  • NG2項目放置位置

發佈內容放到content目錄下,所以index頁面需要在head中設置<base href="/content/dist/">。

  • 實現內容

  1. ng2的路由可以正確使用
  2. 再刷新頁面等操作時,mvc的路由能正確引導NG2的路由。不會出現無法訪問頁面的錯誤。
有其他更好的方法去操作,還請園友不吝賜教,再此謝過。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文:https://zhidao.baidu.com/question/435088233.htmlRMS有兩種方式: 1、使用微軟的伺服器,這個是連接到微軟的伺服器上面做許可權控制,在今年5月份之前即使盜版OFFICE軟體,使用任何hotmail或live的郵箱全部都能使用,5月份之後盜版軟體上去... ...
  • CentOS6.5查看防火牆的狀態: 顯示結果: CentOS 6.5關閉防火牆 CentOS 7.2關閉防火牆 CentOS 7.0預設使用的是firewall作為防火牆,這裡改為iptables防火牆步驟。 firewall-cmd --state #查看預設防火牆狀態(關閉後顯示notrunn ...
  • # cd /etc/yum.repos.d/ # mv CentOS-Base.repo CentOS-Base.repo.bak # wget http://mirrors.163.com/.help/CentOS6-Base-163.repo # mv CentOS6-Base-163.repo... ...
  • 原文地址:http://blog.csdn.net/ausboyue/article/details/52775281 Linux SSH命令錯誤:ECDSA host key "ip地址" for has changed and you have requested strict checking... ...
  • 原文地址:http://www.cnblogs.com/cocowool/archive/2012/07/05/2578487.html YUM代理設置 編輯/etc/yum.conf,在最後加入 # Proxy proxy=http://username:password@proxy_ip:por... ...
  • 1、Bin 目錄 用來存放編譯的結果,bin是二進位binary的英文縮寫,因為最初C編譯的程式文件都是二進位文件,它有Debug和Release兩個版本,分別對應的文件夾為bin/Debug和bin/Release,這個文件夾是預設的輸出路徑,我們可以通過:項目屬性—>配置屬性—>輸出路徑來修改。 ...
  • 1、在程式最前面加: #define _CRT_SECURE_NO_DEPRECATE 2、在程式最前面加: #pragma warning(disable:4996) 3、把scanf改為scanf_s; 4、無需在程式最前面加那行代碼,只需在新建項目時取消勾選“SDL檢查”即可; 5、若項目已建 ...
  • 一、下麵是在創建一個新的項目是我最常用的,現在對他們一一做一個詳細的介紹: 1、Win32控制台應用程式我平時編寫小的C/C++程式都用它,它應該是用的最多的。 2、名稱和解決方案名稱的區別:名稱是項目的名稱,一個解決方案中可以包含多個項目,所以解決方案名稱包含項目名稱。 3、新建Git存儲庫(G) ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...