ASP.NET MVCレッスン7.ブートストラップ、jQuery、Ajax

レッスンの目的 :html、js、cssファイルを操作するためのルールを定義します。 ブートストラップとオプションのcss。 jsファイルの構造。 jQuery、ハイライト、セレクター、イベントなどの使用。addClass、removeClass、attr、data、domオブジェクトの動的作成、ajax。



最後に、クライアント部分のより詳細な調査を開始します。これは、すでにasp.net mvcとの関連性は低くなっていますが、Web開発には依然として重要です。





TwitterブートストラップとCSS


Twitter Bootstrapはcssフレームワークです。 つまり ブロック、ボタン、ラベル、形状、ナビゲーションを作成するためのツールのセット。 このフレームワークに基づいてアプリケーションを作成します。



詳細はこちら:

http://twitter.github.com/bootstrap/

ブートストラップをインストールします。

Install-Package Twitter.Bootstrap
      
      







Jquery.UIを削除します。

 Uninstall-Package Jquery.UI.Combined
      
      







bootstapをBundleConfigに追加し、そこからjquery.UI(App_Start / BundleConfig.cs)を削除します。

 public class BundleConfig { public static void RegisterBundles(BundleCollection bundles) { bundles.Add(new ScriptBundle("~/bundles/jquery").Include( "~/Scripts/jquery-1.*")); bundles.Add(new ScriptBundle("~/bundles/modernizr").Include( "~/Scripts/modernizr-*")); bundles.Add(new ScriptBundle("~/bundles/bootstrap").Include( "~/Scripts/bootstrap*")); bundles.Add(new StyleBundle("~/Content/css") .Include("~/Content/site.css") /*    */ .Include("~/Content/bootstrap*")); } }
      
      







スタイル設定の優先順位について覚えておくことが重要です。







スタイル設定の主な作業は、タグ、クラス(擬似クラス)、および属性の助けを借りて行われます。 style属性でスタイルを設定し、ID属性を使用するのと同様に、 !important



を使用することはお勧めしません。

スタイルを設定するには、cssファイルSite.cssを使用します。 ブートストラップにはすでに基本的なフォームのスタイルがあるため、このブロックを削除してファイル(/Content/Site.css)を残します。

 /* Styles for validation helpers -----------------------------------------------------------*/ .field-validation-error { color: #f00; } .field-validation-valid { display: none; } .input-validation-error { border: 1px solid #f00; background-color: #fee; } .validation-summary-errors { font-weight: bold; color: #f00; } .validation-summary-valid { display: none; }
      
      







これらは、 Html.ValidationMessage()



Html.ValidationSummary()



メソッドでエラーを表示するために使用されるcssスタイルです。

次に、独自のスタイルを作成するルールを定義します。





htmlページの構造。


スタイルファイルとjsファイルをメインレイアウトファイル(/Areas/Default/Views/Shared/_Layout.cshtml)に接続します。

 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width" /> <title>@ViewBag.Title</title> @Styles.Render("~/Content/css") @RenderSection("styles", required: false) @Scripts.Render("~/bundles/modernizr") </head> <body> <div class="navbar navbar-fixed-top"> <div class="navbar-inner"> <div class="container"> <ul class="nav nav-pills pull-right"> @Html.Action("UserLogin", "Home") </ul> </div> </div> </div> @RenderBody() @Scripts.Render("~/bundles/jquery") @Scripts.Render("~/bundles/bootstrap") @RenderSection("scripts", required: false) </body> </html>
      
      







ここで何が起こっていますか:

  1. リクエストを取得し、リクエストに応じてルート/デフォルト/ホーム/インデックスを定義します。
  2. このコントローラー/メソッドには標準ビューがあります-/Home/Index.cshtml




ファイルの先頭で、レイアウトに含まれることが宣言されています。

 @{ ViewBag.Title = "LessonProject"; Layout = "~/Areas/Default/Views/Shared/_Layout.cshtml"; }
      
      





指定されたレイアウトは、 @RenderBody()



を使用してデータを出力します。 以下を開始します。







ナビゲーションバーの下で体が運転したことがわかります。 このファイルでは、本文(/Content/Site.css)を再定義します。

 body { padding-top : 40px !important; }
      
      









はるかに良い。



前にbootstapフォームにクラスを使用したため、登録は次のようになります。







生年月日の選択を修正して、クラスをHtml .DropDownList()(/Areas/Default/Views/User/Register.cshtml)に追加します。



 <div class="controls"> @Html.DropDownList("BirthdateDay", Model.BirthdateDaySelectList, new { @class = "select-day" }) @Html.DropDownList("BirthdateMonth", Model.BirthdateMonthSelectList, new { @class = "select-month" }) @Html.DropDownList("BirthdateYear", Model.BirthdateYearSelectList, new { @class = "select-year" }) </div>
      
      







他のどこかでこの構造を使用して日付を選択する可能性が高いため(事実ではありません)、これは特定の日付(特に登録に関連する)よりも一般的です(/Content/Site.css)



 .select-day { width : 50px; } .select-month { width : 90px; } .select-year { width : 70px; }
      
      







私たちはチェックします:







うーい!



Jsファイル構造


jsファイルの説明に渡します。 コードのクライアント部分を操作するためのメインフレームワークとしてjqueryを使用します。 カスタムjsファイルの1つ(/Scripts/common.jsと呼びましょう)は常に呼び出されます。 任意のページに存在する関数を追加します。 他のjsファイルはオプションで呼び出されます。



混乱しないように、/ Scriptsに「admin」と「default」の2つのフォルダーを作成します。



すべてのファイルには、SmallCase形式で書き込まれる一意の名前が付けられ、特定のページ(ほとんど)を参照します。 例:user-register.js-User / Register.cshtmlページに含まれるファイル:



 @section scripts { @Scripts.Render("/Scripts/default/user-register.js") }
      
      







このセクションは、_Layout.cshtml(/Areas/Default/Views/Shared/_Layout.cshtml)で説明されている場所に表示されます。

 … @Scripts.Render("~/bundles/bootstrap") @Scripts.Render("~/bundles/common") @RenderSection("scripts", required: false) </body>
      
      







それまでの/App_Start/BundleConfig.csで、説明を追加します。

  bundles.Add(new ScriptBundle("~/bundles/common").Include( "~/Scripts/common.js"));
      
      







プラグインを除くすべてのカスタムjsクラスの構造は次のとおりです。

 function FunctionName() { _this = this; this.init = function () { /*       */ $("button").click(function () { var id = $(this).attr("id"); _this.saySomething(id); }); } /*   */ this.saySomething = function (id) { alert("-! : " + id); } /*    */ function saySomething (id) { alert("-!  !: " + id); } } var functionName = null; $().ready(function () { functionName = new FunctionName(); functionName.init(); });
      
      







さらに詳しく考えてみましょう。

  1. function FunctionName



    は、それが配置されているファイルの名前によるUpperCamelCaseスタイル名があります(ファイルcommon.jsおよびuser-register.jsのCommon



    およびUserRegister



    )。
  2. _this = this;



    この関数へのリンクを保存して、デリゲート関数内で使用できるようにします
  3. this.init()



    は、処理が初期化される外部(パブリック)関数です。
  4. var functionName = null



    グローバル変数を作成します。 他のファイルからの使用が可能です。
  5. $().ready()



    -DOM構造が形成された後に呼び出されます。 JQuery関数。
  6. functionName = new FunctionName();



    -クラスオブジェクトを作成します。
  7. functionName.init();



    -初期化する。




リソースファイルの縮小




リソースファイルは時間とともに増大し、一方で、モバイルデバイス向けのモバイルインターネットの開発があり、送信データの量が重要な役割を果たすため、ページの受信の縮小は次のようになります。





画像、特に小さな画像に対するリクエストの数を減らします。 これは2つの方法で行われます。



  1. スプライトを使用します。 多くのデザイン要素が一度に大きなキャンバスに追加されます。 その後、このキャンバスの一部のオフセットと幅\高さがcssで書き込まれます。

    たとえば、画像:





    そして、htmlでの使用:

     <div class="label label-new sprite"></div>
          
          





    そしてCSS:

     .sprite { background: url("/Media/images/sprite.png"); overflow: hidden; text-indent: -9999px; } .box .label { position: absolute; width: 29px; right: -29px; top: 35px; } .box .label-new { background-position: 0 -15px; height: 119px; }
          
          





  2. 2. base64でエンコードすることにより、CSSで直接非常に小さな画像(アイコン)の広告を使用します。

    これを行うために、画像は、たとえばhttp://webcodertools.com/imagetobase64converterの base64に転送されます

    次に、タイプ別にcssに追加します。

     background-image: url();
          
          









もちろん、コンテンツのアイコンまたは画像を読み込む場合、この方法は適用できません。



cssおよびjsの場合、ファイルの縮小が使用されます。 スペースと区切り文字は削除され、短いローカル変数が使用されます。 ファイルは、jqueryライブラリのように縮小された状態で最初に準備されるか、サーバーで縮小されます。



縮小を有効にするには、Web.configファイルのコンパイルディレクティブを変更する必要があります。

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







または、/ App_Start / BundleConfig.csに直接含めます。



 BundleTable.EnableOptimizations = true;
      
      







チェック:





最大527Kの最適化







最適化後、251 KB



つまり 2回以上。 実際、この値は、ロードするリソースに応じて、これよりも小さくも大きくもなります。 キャッシュがある場合、ページは追加の作業中に新しいファイルのごく一部のみをダウンロードします。



JQueryのインストール

最初、jqueryはすでにインストールされていますが、フレームワークが更新され、これが頻繁に行われる場合、更新する必要があることは明らかです。

インストールパッケージjQuery



さらに、datepicker、モーダル関数をブートストラップが提供するものから使用するため、以前にJQueryUI( http://jqueryui.com/ )を削除しました。 しかし、JQueryUIには、必要な相互作用機能、つまり ドラッグ可能、ドロップ可能、サイズ変更可能、選択可能、およびソート可能。 それらを選択的にインストールします。

  1. Install-Package JQuery.UI.Interactionsはjqueryバージョン<1.6を必要とするため、手動でインストールします。
  2. jqueryui.com/downloadからカスタムダウンロードを選択します
  3. コアとインタラクションのみを選択します
  4. 振り回す
  5. CSSファイルを/コンテンツ/ CSSに転送します
  6. jsファイルを/スクリプトに転送します(jquery-1.9.1-min.jsは転送する必要はありません)
  7. BundleConfigで接続します

      bundles.Add(new ScriptBundle("~/bundles/jqueryui") .Include("~/Scripts/jquery-ui-1.*")); bundles.Add(new StyleBundle("~/Content/css/jqueryui") .Include("~/Content/jquery-ui-1*"));
          
          





  8. 必要に応じて、ページで発表します。
  9. できた!




Firebug(Firefox)および開発者ツール(Chrome)


デバッグの利便性のため、FirefoxにはFirebug拡張機能があり、Chromeには組み込みの開発者ツールメカニズムがあります。 開発者ツールの例を見てみましょう。 キーストロークShift-Ctrl-I



によって呼び出されます。



勉強しましょう:





セレクターとバイパス


JQueryは、さまざまなブラウザー用のクライアントコードの開発を支援するツールです。 また、シンプルで論理的なライブラリです。



すべての中心にセレクターがあります。 セレクターを使用すると、DOM(ドキュメントオブジェクトモデル)にある多くの要素を選択し、それらに対してアクションを実行できます:イベントハンドラーの割り当て、場所の変更、属性の変更、選択した要素の削除、選択した要素へのテキストまたはhtmlの追加、オブジェクトの作成。



基本的なルールは次のように書かれています。



$([“ ”][, ])







選択領域が指定されていない場合、ドキュメント全体で検索されます:$(ドキュメント)。 これは、DOM全体のルートノードです。

選択領域が指定されている場合、このノードの境界でのみ検索されます。

セレクタールールは、CSSプロパティを割り当てる原則に従って設定されます。



要素が見つかったかどうかを確認するには、lengthプロパティを使用できます。

 if($("#Id1").length == 0) { alert("  ") }
      
      





選択した要素のツリーを上に移動するには、関数.closest()、. parent()、または.parents()を使用できます。





イベント




イベントを処理するには、セレクター要素にイベントを割り当てます。 例:

 $(".button").click(function () { alert("Button clicked"); });
      
      





イベントとは:





イベントは、新しく作成された要素には適用されませんが、以前に実行されたセレクターの選択に該当することに注意してください。 ただし、2回目の初期化を行うと、イベント処理が既に割り当てられている要素では、このイベントが2回実行されます。



一定のグローバル処理を設定するには、次の構成を使用する必要があります。



 $(document).on("click", ".button", function () { alert("Button clicked"); });
      
      







属性と値




要素の属性を操作するには、主に次の関数が使用されます。





基本的な操作


要素を操作するには、次の関数を検討してください。





アヤックス


メイン関数とメイン関数を考えてみてください(99%のケースで、私はそれだけでした)。

 $.ajax({ type: "GET", url: "/ajaxUrl", data: { id: id }, beforeSend: function () { /* -   */ }, success: function (data) { /*   */ }, error: function () { /*   */ } });
      
      







他にもパラメータがありますが、場合によってはそれらに頼る価値があります。

パラメーターをさらに詳しく考えてみましょう。





Ajaxログインフォーム。


理論の束、それは練習に移る時間です。 2つ目のログインフォームを作成して、サイトにすばやくログインできるようにします。 [ログイン]をクリックすると、ログインページには移動しません。代わりに、ポップアップウィンドウがポップアップし、すぐにログインを入力するように提案されます。 入力に誤りがある場合、フォームは警告を出します。 / Loginに通常のフォームを残します。必要になります。

Popapフォームは頻繁に使用される可能性があるため、これを標準的な手順と見なします。このようなアドレスでPopupを呼び出します。 ポップアップは常に1つなので、_Layout.cshtml(/Areas/Default/Views/Shared/_Layout.cshtml)にポップアップ用のコンテナーを作成します。

  <div id="PopupWrapper"></div>
      
      







common.js(/Scripts/common.js)に機能を追加します。

 this.showPopup = function (url, callback) { $.ajax({ type: "GET", url: url, success: function (data) { $(".modal-backdrop").remove(); var popupWrapper = $("#PopupWrapper"); popupWrapper.empty(); popupWrapper.html(data); var popup = $(".modal", popupWrapper); $(".modal", popupWrapper).modal(); callback(popup); } }); }
      
      





, .modal() – bootstrap.js.



, common.js:

  this.init = function () { $("#LoginPopup").click(function () { _this.showPopup("/Login/Ajax", function (modal) { }); }); }
      
      







(/Areas/Default/Controller/LoginController.cs):

 [HttpGet] public ActionResult Ajax() { return View(new LoginView()); } [HttpPost] public ActionResult Ajax(LoginView loginView) { if (ModelState.IsValid) { var user = Auth.Login(loginView.Email, loginView.Password, loginView.IsPersistent); if (user != null) { return RedirectToAction("Index", "Home"); } ModelState["Password"].Errors.Add("  "); } return View(loginView); }
      
      







Index, View – «Ajax», (/Areas/Default/Views/Login/Ajax.cshtml):







 @model LessonProject.Models.ViewModels.LoginView <div class="modal hide fade" tabindex="-1" role="dialog" aria-hidden="true"> <div class="modal-header"> <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> <h3 id="myModalLabel">Login</h3> </div> <div class="modal-body"> @using (Html.BeginForm("Ajax", "Login", FormMethod.Post, new { @class = "form-horizontal", id = "LoginForm" })) { <fieldset> <legend></legend> <div class="control-group"> <label class="control-label" for="Email"> Email</label> <div class="controls"> @Html.TextBox("Email", Model.Email, new { @class = "input-xlarge" }) <p class="help-block"> Email</p> @Html.ValidationMessage("Email") </div> </div> <div class="control-group"> <label class="control-label" for="Password"> </label> <div class="controls"> @Html.Password("Password", Model.Password, new { @class = "input-xlarge" }) @Html.ValidationMessage("Password") </div> </div> </fieldset> } </div> <div class="modal-footer"> <button class="btn" data-dismiss="modal" aria-hidden="true">Close</button> <button class="btn btn-primary" id="LoginButton">Login</button> </div> </div>
      
      







id LoginForm id LoginButton



UserLogin.cshtml (/Areas/Default/Views/Home/UserLogin.cshtml):

  <li><span class="btn btn-link" id="LoginPopup"></span></li>
      
      







common.js LoginButton, $(“#LoginButton”).click(…) (/Scripts/common.js):

 this.init = function () { $("#LoginPopup").click(function () { _this.showPopup("/Login/Ajax", initLoginPopup); }); } … function initLoginPopup(modal) { $("#LoginButton").click(function () { $.ajax({ type: "POST", url: "/Login/Ajax", data : $("#LoginForm").serialize(), success: function (data) { showModalData(data); initLoginPopup(modal); } }); }); } function showModalData(data, callback) { $(".modal-backdrop").remove(); var popupWrapper = $("#PopupWrapper"); popupWrapper.empty(); popupWrapper.html(data); var popup = $(".modal", popupWrapper); $(".modal", popupWrapper).modal(); if (callback != undefined) { callback(popup); } }
      
      







再帰呼び出しに注意してくださいinitLoginPopup



そして、ここにジレンマがあります。ログインに成功すると、PopupWrapperで新しいページ(またはエラーのあるページ)を読み込む必要はなく、ページを更新するだけです。



これを行うには、トリックを行います。/エリア/デフォルト/ビュー/共有/ _Ok.cshtmlを追加します。その本質はページをリロードすることです。

 <script> window.location.reload(); </script>
      
      





ログインに成功すると、このビューをロードします。DOMを行のツリーに追加する場合

 popupWrapper.html(data);
      
      





スクリプトは、他の呼び出しを待たずにページを開始してリロードします。コントローラーを変更します(/Areas/Default/Controllers/LoginController.cs):

 var user = Auth.Login(loginView.Email, loginView.Password, loginView.IsPersistent); if (user != null) { return View("_Ok"); }
      
      







チェック、動作します!



まとめ


, , , .

Chrome ajax . .

便利なリンク:

http://jquery.com

http://habrahabr.ru/post/161895/

http://habrahabr.ru/post/154687/

http://twitter.github.com/bootstrap/

http://habrahabr.ru/post/160177/



すべてのソースはhttps://bitbucket.org/chernikov/lessonsにあります



All Articles