検索
ホームページバックエンド開発C#.Net チュートリアルASP.NET MVC がブートストラップを使用する方法の分析例

ASP.NET MVC がブートストラップを使用する方法の分析例

Sep 18, 2017 am 11:11 AM
asp.netbootstrap事例分析

この記事では主に ASP.NET MVC で Bootstrap を使用する方法を紹介します。編集者が非常に優れていると考えたので、参考として共有します。エディターをフォローして見てみましょう

Web 開発者として、フロントエンド フレームワークを使用せずに、HTML と CSS を使用して使いやすいページを最初から構築するのは非常に困難です。特に Windows フォーム開発者にとって、これはさらに困難です。

Bootstrap が生まれたのはこのためです。 Twitter Bootstrap は、開発者に豊富な CSS スタイル、コンポーネント、プラグイン、レスポンシブ レイアウトなどを提供します。同時に、Microsoft は ASP.NET MVC テンプレートに完全に統合されました。

Bootstrap の構造の概要

Bootstrap の最新バージョンをダウンロードします。

フォルダーを解凍すると、Bootstrap のファイル配布構造は次のとおりで、3 つのフォルダーが含まれていることがわかります:

  • css

  • fonts

  • js

css フォルダーには 4 つの .css ファイルが含まれています。および 2 つの .map ファイル。プロジェクトに bootstrap.css ファイルを含めるだけで、Bootstrap をページに適用できるようになります。 bootstrap.min.css は、上記の CSS の圧縮バージョンです。

.map ファイルはプロジェクトに含める必要はなく、無視しても問題ありません。これらのファイルはデバッグ シンボル (Visual Studio の .pdb ファイルと同様) として使用され、最終的には開発者が前処理されたファイルをオンラインで編集できるようになります。

Bootstrap は、Font Awesome (フォント ファイルには、Bootstrap 専用に設計されたすべてのグリフ アイコンが含まれています) を使用して、さまざまなアイコンとシンボルを表示します。

  • Embedded OpenType (glyphicons-halflings) の 4 種類のフォント ファイルが含まれています。 -レギュラー.eot)

  • スケーラブル ベクター グラフィックス (glyphicons-halflings-normal.svg)

  • TrueType フォント (glyphicons-halflings-regulator.ttf)

  • Web オープン フォント フォーマット (glyphicons -halflings-regulator) .woff)

Web アプリケーションにすべてのフォント ファイルを含めることをお勧めします。これにより、サイトがさまざまなブラウザーで正しいフォントを表示できるようになります。

EOT フォント形式ファイルは IE9 以降のブラウザでサポートされている必要があります。TTF は従来の古いフォント形式ファイルで、WOFF は TTF から圧縮されたフォント形式ファイルです。 IE8 以降のブラウザ、iOS 4 以降、および Android のみをサポートする必要がある場合は、WOFF フォントを含めるだけで済みます。

js フォルダーには 3 つのファイルが含まれています。bootstrap.min.js は、プロジェクト構築ツール Grunt を通じて自動的に生成された、上記の js の圧縮バージョンです。

すべての Bootstrap プラグインには JQuery が必要であるため、boostrap.js ファイルを参照する前に、JQuery ライブラリを参照していることを確認してください。

ASP.NET MVC プロジェクトにブートストラップ ファイルを追加する

Visual Studio 2013 を開き、以下に示すように、標準の ASP.NET MVC プロジェクトを作成します。デフォルトでは、すべてのブートストラップ ファイルが自動的に追加されます。 Microsoft が Bootstrap を非常に認識しており、Visual Studio に高度に統合されていることがわかります。

_references.js という名前のファイルがスクリプト ファイルに追加されることに注意してください。これは、Bootstrap などの一部のフロントエンド ライブラリを使用するときに、Visual Studio でスマート プロンプトを有効にするのに役立ちます。

もちろん、空の ASP.NET MVC プロジェクトを作成してこれらの依存関係ファイルを手動で追加することもできます。以下の図に示すように、空のテンプレートを選択します:

新しく作成した空の ASP.NET MVC プロジェクトの場合、Content、Fonts、Scripts フォルダーはありません - 以下に示すように、手動で作成する必要があります:

もちろん、Nuget を使用して Bootstrap リソース ファイルを自動的に追加することもできます。グラフィカル インターフェイスを使用して Bootstrap Nuget パッケージを追加する場合は、「Bootstrap」を直接検索します。パッケージ マネージャー コンソールを使用して Bootstrap Nuget パッケージを追加する場合は、「Install-Package bootstrap」と入力します。

Web サイトのレイアウト ページを作成します

Web サイトの一貫したスタイルを維持するために、Bootstrap を使用してレイアウト ページを構築します。以下の図に示すように、Views フォルダーに MVC レイアウト ページ (Razor) レイアウト ファイルを作成します。

新しく作成したレイアウト レイアウト ページで、次のコードを使用してブートストラップ リソース ファイルを参照します。

<link href="@Url.Content(" rel="external nofollow" rel="external nofollow" ~/css/bootstrap.css")" rel="stylesheet">

<script src="@Url.Content("~/js/bootstrap.js")"></script>

@Url.Content を使用すると、仮想パスまたは相対パスが絶対パスに変換され、ブートストラップ リソース ファイルが確実に参照されます。

以下に示すように、Home という名前の新しいコントローラーを作成し、デフォルトのインデックス ビューを追加して、上記のレイアウト レイアウト ページを適用します。

使用捆绑打包和压缩来提升网站性能

捆绑打包(bundling)和压缩(minification)是ASP.NET中的一项新功能,允许你提升网站加载速度,这是通过限制请求CSS和JavaScript文件的次数来完成的。本质上是将这类文件结合到一个大文件以及删除所有不必要的字符(比如:注释、空格、换行)。

对于大多数现代浏览器访问一个主机名都有6个并发连接的极限,这意味着如果你在一张页面上引用了6个以上的CSS、JavaScript文件,浏览器一次只会下载6个文件。所以限制资源文件的个数是个好办法,真正意义上的使命必达,而不是浪费在加载资源上。

在Bootstrap项目中使用捆绑打包

因为我们创建的是空的ASP.NET MVC项目,所以并没有自动引用与打包相关的程序集。打开Nuget Package Manager Console来完成对Package的安装,使用如下PowerShell命令:

install-package Microsoft.AspNet.Web.Optimization 来安装Microsoft.AspNet.Web.Optimization NuGet package以及它依赖的Package,如下所示:

在安装完成后,在App_Start中添加 BundleConfig类:


public static void RegisterBundles(BundleCollection bundles)
{
  bundles.Add(new ScriptBundle("~/bootstrap/js").Include(
  "~/js/bootstrap.js",
  "~/js/site.js"));
  bundles.Add(new StyleBundle("~/bootstrap/css").Include(
  "~/css/bootstrap.css",
  "~/css/site.css"));
}

ScriptBundle和StyleBundle对象实例化时接受一个参数用来代表打包文件的虚拟路径,Include顾名思义将你需要的文件包含到其中。

然后在Application_Start方法中注册它:


protected void Application_Start()
{
  AreaRegistration.RegisterAllAreas();
  RouteConfig.RegisterRoutes(RouteTable.Routes);
  BundleConfig.RegisterBundles(BundleTable.Bundles);
  BundleTable.EnableOptimizations = true;
}

记住,不要去包含.min类型的文件到打包文件中,比如bootstrap.min.css、bootstrap.min.js,编译器会忽略这些文件因为他们已经被压缩过了。

在ASP.NET MVC 布局页使用@Styles.Render("~/bootstrap/css")、@Scripts.Render("~/bootstrap/js")来添加对打包文件的引用。

如果Visual Studio HTML编辑器表明无法找到Styles和Scripts对象,那就意味着你缺少了命名空间的引用,你可以手动在布局页的顶部添加System.Web.Optimization 命名空间,如下代码所示:


@using System.Web.Optimization
<!DOCTYPE html>
<html>
 <head>
 <meta name="viewport" content="width=device-width" />
 <title>@ViewBag.Title</title>
 @*<link href="@Url.Content(" rel="external nofollow" rel="external nofollow" ~/css/bootstrap.css")" rel="stylesheet">
 <script src="@Url.Content("~/js/bootstrap.js")"></script>*@
 @Scripts.Render("~/bootstrap/js")
 @Styles.Render("~/bootstrap/css")
 </head>
 <body>
 <p>
  @*@RenderBody()*@
 </p>
</body>
</html>

当然为了通用性,最佳的实践是在Views文件夹的web.config中添加System.Web.Optimization名称空间的引用,如下所示:


<namespaces>
 <add namespace="System.Web.Mvc" />
 <add namespace="System.Web.Mvc.Ajax" />
 <add namespace="System.Web.Mvc.Html" />
 <add namespace="System.Web.Routing" />
 <add namespace="Bootstrap.Web" />
 <add namespace="System.Web.Optimization" />
</namespaces>

测试打包和压缩

为了使用打包和压缩,打开网站根目录下的web.config文件,并且更改compilation元素的dubug属性为false,即为release。


<system.web>

 <compilation debug="false" targetFramework="4.5" />

 <httpRuntime targetFramework="4.5" />

</system.web>

当然你可以在Application_Start方法中设置BundleTable.EnableOptimizations = true来同样达到上述效果(它会override web.config中的设置,即使debug属性为true)。

最后浏览网页,查看源代码,可以清楚看到打包文件的路径是之前定义过的相对路径,点击这个链接,浏览器为我们打开了经过压缩处理过后的打包文件,如下图所示:

小结

在这一章节中,简单为大家梳理了Bootstrap的体系结构,然后怎样在ASP.NET MVC项目中添加Bootstrap,最后使用了打包和压缩技术来实现对资源文件的打包,从而提高了网站的性能。

以上がASP.NET MVC がブートストラップを使用する方法の分析例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
C#.NET:コアの概念とプログラミングの基礎を探るC#.NET:コアの概念とプログラミングの基礎を探るApr 10, 2025 am 09:32 AM

C#は、Microsoftによって開発された最新のオブジェクト指向プログラミング言語であり、.NETフレームワークの一部として開発されています。 1.C#は、カプセル化、継承、多型を含むオブジェクト指向プログラミング(OOP)をサポートしています。 2。C#の非同期プログラミングは非同期を通じて実装され、適用応答性を向上させるためにキーワードを待ちます。 3. LINQを使用してデータ収集を簡潔に処理します。 4.一般的なエラーには、null参照の例外と、範囲外の例外インデックスが含まれます。デバッグスキルには、デバッガーと例外処理の使用が含まれます。 5.パフォーマンスの最適化には、StringBuilderの使用と、不必要な梱包とボクシングの回避が含まれます。

テストC#.NETアプリケーション:ユニット、統合、およびエンドツーエンドテストテストC#.NETアプリケーション:ユニット、統合、およびエンドツーエンドテストApr 09, 2025 am 12:04 AM

C#.NETアプリケーションのテスト戦略には、ユニットテスト、統合テスト、エンドツーエンドテストが含まれます。 1.単位テストにより、コードの最小ユニットがMSTEST、ヌニット、またはXUNITフレームワークを使用して独立して動作することを保証します。 2。統合テストでは、一般的に使用されるシミュレートされたデータと外部サービスを組み合わせた複数のユニットの機能を検証します。 3.エンドツーエンドのテストでは、ユーザーの完全な操作プロセスをシミュレートし、通常、セレンは自動テストに使用されます。

高度なC#.NETチュートリアル:次のシニア開発者インタビューをエース高度なC#.NETチュートリアル:次のシニア開発者インタビューをエースApr 08, 2025 am 12:06 AM

C#シニア開発者とのインタビューでは、非同期プログラミング、LINQ、.NETフレームワークの内部作業原則などのコア知識をマスターする必要があります。 1.非同期プログラミングは、非同期を通じて操作を簡素化し、アプリケーションの応答性を向上させるのを待ちます。 2.LinqはSQLスタイルでデータを操作し、パフォーマンスに注意を払います。 3.ネットフレームワークのCLRはメモリを管理し、ガベージコレクションに注意して使用する必要があります。

c#.netインタビューの質問と回答:専門知識を高めるc#.netインタビューの質問と回答:専門知識を高めるApr 07, 2025 am 12:01 AM

C#.NETインタビューの質問と回答には、基本的な知識、コアの概念、高度な使用が含まれます。 1)基本知識:C#は、Microsoftが開発したオブジェクト指向言語であり、主に.NETフレームワークで使用されています。 2)コアの概念:委任とイベントは動的な結合方法を可能にし、LINQは強力なクエリ関数を提供します。 3)高度な使用:非同期プログラミングは応答性を向上させ、式ツリーは動的コード構造に使用されます。

C#.NETを使用したマイクロサービスの構築:建築家向けの実用的なガイドC#.NETを使用したマイクロサービスの構築:建築家向けの実用的なガイドApr 06, 2025 am 12:08 AM

C#.NETは、その強力なエコシステムと豊富なサポートのため、マイクロサービスを構築するために人気のある選択肢です。 1)asp.netcoreを使用してRestfulapiを作成して、順序の作成とクエリを処理します。 2)GRPCを使用して、マイクロサービス間の効率的な通信を実現し、注文サービスを定義および実装します。 3)Dockerコンテナ化されたマイクロサービスを介して展開と管理を簡素化します。

C#.NETセキュリティベストプラクティス:一般的な脆弱性の防止C#.NETセキュリティベストプラクティス:一般的な脆弱性の防止Apr 05, 2025 am 12:01 AM

C#および.NETのセキュリティベストプラクティスには、入力検証、出力エンコード、例外処理、認証と承認が含まれます。 1)正規表現または組み込みのメソッドを使用して入力を検証して、悪意のあるデータがシステムに入るのを防ぎます。 2)XSS攻撃を防ぐための出力エンコード、httputility.htmlencodeメソッドを使用します。 3)例外処理により、情報の漏れが回避され、エラーが記録されますが、詳細情報はユーザーに返されません。 4)ASP.Netidentityおよび請求に基づく許可を使用して、不正アクセスから申請を保護します。

C言語で:それはどういう意味ですかC言語で:それはどういう意味ですかApr 03, 2025 pm 07:24 PM

C言語におけるコロン( ':')の意味:条件付きステートメント:条件付き式とステートメントの分離ブロックループステートメント:初期化、条件付きおよび増分式のマクロ定義の分離:マクロ名とマクロ値の分離単一行コメント:コメントアレイの寸法としてのコロンから行までのコンテンツを表す:アレイの寸法を指定する

C言語では何を意味しますかC言語では何を意味しますかApr 03, 2025 pm 07:21 PM

c言語は、後の運動後演算子であり、その動作メカニズムには次のものが含まれます。最初に変数の値を取得します。 aの値を1 x1。増加した後、aの値を返します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。