0917-062-0010

مشاوره رایگان

9 صبح تا 9 شب

شنبه تا پنجشنبه

آموزش مقدماتی Bundling و Minification در ASP.NET MVC + معرفی دوره

«بسته‌بندی» (Bundling) و «کمینه‌سازی» (Minification)، دو روش بسیار محبوب برای افزایش کارایی وب اپلیکیشن‌های امروزی به‌شمار می‌روند. عمل Bundling تعداد «درخواست‌های» (Requests) ارسالی به سمت سرور، و Minification، اندازه asset‌های درخواستی (فایل‌های ایستا روی سرور) را کاهش می‌دهد. در این مطلب، Bundling و Minification در ASP.NET MVC و نحوه کار آن بیان شده است. پس از آن، تاثیر اِعمال این دو ویژگی روی سرعت بارگذاری صفحات وب را بررسی خواهیم کرد. همچنین در مورد دیباگ کردن اسکریپت‌های جاوا اسکریپت و نحوه تنظیمات آن نیز توضیحاتی ارائه شده است.

فهرست مطالب این نوشته
Bundling و Minification در ASP.NET MVC

بسته بندی یا Bundling در ASP.NET چیست ؟

کمینه سازی Minification در ASP.NET چیست ؟

تاثیر Bundling و Minification روی عملکرد برنامه

دیباگ جاوا اسکریپت Bundling و Minification شده

تنظیم و کنترل Bundling و Minification در ASP.NET MVC

استفاده از Bundling و Minification در وب فرم‌ها و صفحات وب

Bundling و Minification در صفحات وب

بکارگیری Bundleها

Bundling و Minification در وب فرم ها

ایجاد باندل های جی کوئری

ثبت باندل ها

ارجاع به باندل ها

باندل های CSS

استفاده از Bundling و Minification در ASP.NET MVC

استفاده از CDN

نحوه ایجاد باندل در ASP.NET MVC

استفاده از کاراکتر جایگزین «*» برای انتخاب فایل ها

نهان سازی باندل یا Bundle Caching چیست؟

باندلینگ مواردی همچون LESS ،‌CoffeeScript ،SCSS و Sass

ملاحظاتی در مورد باندل ها در ASP.NET MVC

سوالات متداول

قابلیت‌های Bundling و Minification در ASP.NET MVC را چگونه فعال کنیم؟

Bundling و Minification در ASP.NET MVC چه تفاوتی با هم دارند؟

مزیت باندلینگ اسکریپت‌های JS در قالب یک فایل چیست؟

سخن پایانی

faradars mobile

امروزه، وب اپلیکیشن‌ها به لطف وجود دو مولفه فوق‌العاده، یعنی جاوا اسکریپت و CSS، «پاسخگوتر» (Responsive) و جذاب‌تر هستند و می‌توان گفت که پلتفرم وب به وسیله این دو مولفه، قدرتی مهارنشدنی پیدا کرده است. در عین حال ممکن است، افزایش تعداد و حجم این فایل‌های CSS و جاوا اسکریپت، اثرات منفی روی سرعت بارگذاری صفحات داشته باشند. در نوشتار پیشِ رو، سعی شده است نحوه استفاده و کد نویسی Bundling و Minification در ASP.NET MVC تا حد قابل قبولی پوشش داده شود.

Bundling و Minification در ASP.NET MVC

همانطور که گفته شد، باندلینگ و مینیفیکیشن، دو تکنیکی هستند که شما می‌توانید برای بهبود زمان بارگذاری درخواست، در اِی‌اِس‌پی دات‌نت ۴٫۵ استفاده کنید. Bundling زمان بارگذاری را از طریق کاهش تعداد درخواست‌های ارسالی از کاربر به سمت سرور، بهبود می‌دهد. به وسیله Minification نیز اندازه ‎asset‌هایی کاهش پیدا می‌کنند که در درخواست وجود دارند. در نتیجه، سرعت بارگذاری صفحات بهبود می‌یابد. منظور از ‎asset‌ها، همان فایل‌های ایستای روی سرور، مانند تصاویر، فایل‌های CSS، جاوا اسکریپت و غیره هستند که می‌خواهیم آن‌ها را در دسترس دنیای بیرونی (مخاطبین برنامه وب) قرار دهیم.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

امروزه، اکثر مرورگرهای رایج، تعداد «اتصالات همزمان» (Simultaneous Connections) برای هر «نام میزبان» (Hostname) را به ۶ اتصال محدود می‌کنند. اینجا Hostname برچسبی است که به یک دستگاه متصل به اینترنت، برای شناسایی آن در اَشکال مختلف ارتباطات استفاده می‌شود. یعنی در صورتی که ۶ درخواست در حال پردازش باشند، درخواست‌های اضافی برای asset‌ها به‌وسیله مرورگر در صف قرار می‌گیرند. تصویر زیر، زبانه Network از «ابزارهای توسعه‌دهنده» (Developer Tools) مرورگر IE را نشان می‌دهد. برای دسترسی به این ابزار می‌توانیم از کلید میانبر F12 استفاده کنیم. زمان‌بندی asset‌-های مورد نیاز در نمای «About»، در این تصویر قابل مشاهده است.

زمان بندی نمای about در ASP.NET MVC
برای مشاهده تصویر در اندازه اصلی روی آن کلیک کنید

نوارهای خاکستری رنگ، زمان قرارگیری درخواست در صف انتظار (با توجه به محدودیت اتصال ۶ تایی) به‌وسیله مرورگر را نشان می‌دهند. نوار زرد رنگ، بیانگر «زمان اولین بایتِ» (Time to First Byte) درخواست است، یعنی مدت زمانی که از ارسال درخواست تا دریافت اولین پاسخ از سرور طول کشیده است.

آموزش چارچوب توسعه تحت وب ASP.NET MVC
فیلم آموزش چارچوب توسعه تحت وب ASP.NET MVC در تم آف

کلیک کنید

نوارهای آبی رنگی که مشاهده می‌کنید نیز، زمان صرف شده برای دریافت داده‌های پاسخ از سرور هستند. برای دریافت اطلاعات دقیق زمان‌بندیِ asset مورد نظر، می‌توانید روی آن دابِل‌کلیک کنید. به عنوان مثال، تصویر زیر جزئیات زمان بارگذاری فایل /Scripts/MyScripts/JavaScript6.js

 را نشان می‌دهد.

جزئیات زمان بندی بارگذاری اسکریپت
برای مشاهده تصویر در اندازه اصلی روی آن کلیک کنید

تصویر بالا‍ در مورد رویداد Start است که زمان قرار گرفتنِ درخواست را در صف بیان می‌کند. زیرا مرورگر، تعداد اتصالات همزمان را محدود کرده است. در این مورد خاص، درخواست به مدت ۴۶ میلی‌ثانیه در صف منتظر ماند تا درخواست قبلی تکمیل شود.

بسته بندی یا Bundling در ASP.NET چیست ؟

Bundling یکی از ویژگی‌های جدید ASP.NET 4.5 به شمار می‌رود که امکان ترکیب یا «باندل کردن» (گنجاندن) چندین فایل را در یک فایل فراهم می‌کند. شما می‌توانید باندل‌های مختلفی همچون باندل CSS، باندل جاوا اسکریپت و غیره را ایجاد کنید. فایل‌های کمتر به معنای درخواست‌های HTTP کمتری است و این باعث می‌شود تا عملکرد بارگذاری صفحه اول بهبود پیدا کند.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

تصویر زیر، همان زمان‌بندی نمای About را نشان می‌دهد که قبلاً دیدیم، با این تفاوت که این‌بار، ویژگی باندلینگ و کمینه‌سازی روی آن اعمال شده است.

جزدیات زمانبندی نمای about با اعمال Bundling و Minification درASP.NET MVC

کمینه سازی Minification در ASP.NET چیست ؟

با استفاده از Minification، انواع بهینه‌سازی مختلف کدها، روی اسکریپت‌ها یا دستورات CSS اعمال می‌شود. این عملیات، «فضای خالی» (White Space) غیر ضروری و «توضیحات» (Comments) را حذف می‌کند، همچنین نام متغیرها را نیز با هدف کوتاه‌سازی، به یک کاراکتر کاهش می‌دهد.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

تابع جاوا اسکریپتی زیر را در نظر بگیرید.

AddAltToImg = function (imageTagAndImageID, imageContext) {
    ///
    /// Adds an alt tab to the image
    // 
    //The image selector.
    //The image context.
    ///
    var imageElement = $(imageTagAndImageID, imageContext);
    imageElement.attr('alt', imageElement.attr('id').replace(/ID/, ''));
}

پس از انجام کمینه‌سازی، اسکریپت minify شده‌ای به‌صورت زیر خواهیم داشت:

AddAltToImg = function (n, t) { var i = $(n, t); i.attr("alt", i.attr("id").replace(/ID/, "")) }

همان‌طور که مشاهده می‌کنید، علاوه بر حذف کامنت‌ها و فضاهای خالی غیر ضروری، نام پارامترها و متغیرها نیز به صورت زیر تغییر پیدا می‌کند (کوتاه می‌شود):

نام اصلی قبل از کمینه‌سازی
نام تغییر یافته پس از کمینه‌سازی
imageTagAndImageID

n

imageContext

t

imageElement

i

تاثیر Bundling و Minification روی عملکرد برنامه

جدول زیر چندین تفاوت زمانی مهم، بین حالتی که تمام asset‌ها به صورت جداگانه فهرست می‌شوند و همینطور حالتی که Bundling و Minification (به اختصار B/M) اِعمال شده‌اند را در یک نمونه برنامه‌ نشان می‌دهد.

با استفاده از ‌B/M بدون استفاده از B/M میزان تغییر
درخواست‌های فایل ۹ ۳۴ ٪۲۵۶
KB ارسالی ۳٫۲۶ ۱۱٫۹۲ ٪۲۶۶
KB دریافتی ۳۸۸٫۵۱ ۵۳۰ ٪۳۶
زمان بارگذاری ۵۱۰ میلی‌ثانیه ۷۸۰ میلی‌ثانیه ٪۵۳

همانطور که مشاهده می‌شود، میزان بایت‌های ارسالی همراه با ویژگی باندلینگ، کاهش قابل توجهی داشته است، زیرا مرورگرها با بکارگیری سرآیندهایِ HTTP روی درخواست‌ها، آن‌ها را طولانی‌تر می‌کنند. اما به دلیل اینکه فایل‌های بزرگ ما (فایل‌های Scriptsjquery-ui-1.8.11.min.js

و jquery-1.7.1.min.js

 موجود در پوشه Scripts)، از قبل «کمینه» (Minified) شده‌اند، کاهش بایت‌های دریافتی آنقدر زیاد نیست.

توجه داشته باشید که، زمان‌بندی‌های مربوط به نمونه برنامه بالا، با استفاده از ابزار «Fiddler»، شبکه‌ای کم‌سرعت را شبیه‌سازی کرده است. (برای تغییر آن می‌توانید در Fiddler از منوی Rules، ابتدا Performance و در مرحله بعد، Simulate Modem Speeds را انتخاب کنید.)

دیباگ جاوا اسکریپت Bundling و Minification شده

دیباگ کردن جاوا اسکریپت در محیط توسعه، یعنی زمانی که «مولفه کامپایل» (Compilation Element) در Web.config به صورت debug=”true”

 تنظیم شده است، کار سختی نیست. زیرا فایل‌های جاوا اسکریپت هنوز Bundling یا Minification نشده‌اند. شما همچنین می‌توانید نسخه «انتشار» (Release) از فایل‌های جاوا اسکریپت، (که باندلینگ و کمینه‌سازی شده‌اند) را نیز دیباگ کنید.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

با استفاده از ابزارهای توسعه‌دهنده مرورگر IE، می‌توانیم تابع جاوا اسکریپتی کمینه و باندلینگ شده را با مراحلی که در ادامه بیان می‌شود، دیباگ کنیم:

اشکال زدایی تابع جاوا اسکریپت باندل و کمینه شده
برای مشاهده تصویر در اندازه اصلی روی آن کلیک کنید
  1. زبانه Script

     و پس از آن دکمه Start debugging را انتخاب کنید.

  2. باندلِ حاوی تابع جاوا اسکریپتی که می‌خواهید دیباگ کنید را به وسیله دکمه Assets انتخاب کنید.
  3. جاوا اسکریپت کمینه شده را با انتخاب دکمه Configuration و پس از آن Format JavaScript، قالب‌بندی کنید.
  4. در باکس ورودی Search Script، نام تابعی که قصد دیباگ آن را دارید، بنویسید. (در تصویر زیر، AddAltToImg

     در باکس ورودی Search Script وارد شده است.)

اشکل زدایی تابع جاوا اسکریپتی باندل و کمینه شده
برای مشاهده تصویر در اندازه اصلی روی آن کلیک کنید

تنظیم و کنترل Bundling و Minification در ASP.NET MVC

Bundling و Minification در ASP.NET MVC را می توانیم با تنظیم مقدار ویژگی debug در مولفه کامپایل، که در فایل Web.config

وجود دارد، فعال یا غیرفعال کنیم. در XML زیر، مشخصه debug

روی «true» تنظیم شده است، و معنی آن این است که قابلیت Bundling و Minification غیرفعال است.


    
    

برای فعال‌کردن Bundling و Minification در ASP.NET MVC، مقدار debug

را روی «false» تنظیم می‌کنیم.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

شما همچنین می‌توانید تنظیمات Web.config را با ویژگی EnableOptimizations در کلاس BundleTable لغو کنید. کدهای زیر Bundling و Minification را فعال و همه تنظیمات موجود در فایل Web.config را لغو می‌کنند.

public static void RegisterBundles(BundleCollection bundles)
{
    bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
                 "~/Scripts/jquery-{version}.js"));

    // Code removed for clarity.
    BundleTable.EnableOptimizations = true;
}

تا پیش از اینکه ویژگی EnableOptimizations

، true

نشود یا ویژگی debug در فایل Web.config روی false

  تنظیم نشده باشد، فایل‌های ما باندل و کمینه نمی‌شوند. علاوه بر این، به‌جای نسخه «min.» فایل‌ها،‌ نسخه‌های کامل، انتخاب خواهند شد. توجه داشته باشید که EnableOptimizations

ویژگی debug را در مولفه کامپایل در فایل Web.config لغو می‌کند.

استفاده از Bundling و Minification در وب فرم‌ها و صفحات وب

در این قسمت، نحوه باندلینگ و مینیفیکیشن در وب پیج‌ها و وب فُرم‌ها شرح داده می‌شود.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

Bundling و Minification در صفحات وب

افزودن Bundling و Minification به وب‌سایت‌ها از همان روش مورد استفاده توسط ASP.NET MVC و Web Form-ها پیروی می‌کند:

  1. اعلان و ثبت Bundle-ها
  2. بکارگیری Bundle-ها از درون «نماها» (Views)
ایجاد یک وب سایت جدید در ASP.NET
برای مشاهده تصویر در اندازه اصلی روی آن کلیک کنید

برای شروع، یک «Web Pages site» جدید می‌سازیم. سپس فایل _AppStart.cshtml

 را باز می‌کنیم.

باز کردن فایل app start

کدهای زیر را جایگزین محتویات آن می‌کنیم.

@using System.Web.Optimization;

@{
     var bundles = BundleTable.Bundles;
     
     bundles.UseCdn =   true;   //enable CDN support

    //add link to jquery on the CDN
    var jqueryCdnPath = "https://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.7.1.min.js";

    bundles.Add(new ScriptBundle("~/bundles/jquery", 
                jqueryCdnPath).Include(
                "~/Scripts/jquery-{version}.js"));

    bundles.Add(new ScriptBundle("~/bundles/jqueryui").Include(
                "~/Scripts/jquery-ui-{version}.js"));

    bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
                "~/Scripts/jquery.unobtrusive*",
                "~/Scripts/jquery.validate*"));

    bundles.Add(new ScriptBundle("~/bundles/modernizr").Include(
                "~/Scripts/modernizr-*"));

    bundles.Add(new StyleBundle("~/Content/css").Include("~/Content/site.css"));

    bundles.Add(new StyleBundle("~/Content/themes/base/css").Include(
                "~/Content/themes/base/jquery.ui.core.css",
                "~/Content/themes/base/jquery.ui.resizable.css",
                "~/Content/themes/base/jquery.ui.selectable.css",
                "~/Content/themes/base/jquery.ui.accordion.css",
                "~/Content/themes/base/jquery.ui.autocomplete.css",
                "~/Content/themes/base/jquery.ui.button.css",
                "~/Content/themes/base/jquery.ui.dialog.css",
                "~/Content/themes/base/jquery.ui.slider.css",
                "~/Content/themes/base/jquery.ui.tabs.css",
                "~/Content/themes/base/jquery.ui.datepicker.css",
                "~/Content/themes/base/jquery.ui.progressbar.css",
                "~/Content/themes/base/jquery.ui.theme.css"));

}

بکارگیری Bundleها

فایل layout را باز و تگ‌های پیوند CSS و اسکریپت موجود در تگ

را با رفرنس‌های مربوط به Bundle جایگزین می‌کنیم. کدهای اولیه در ادامه نشان داده شده است.



    
        
        @Page.Title - My ASP.NET Web Page
        
        
        
        
        
        
        
    

پس از از اعمال تغییرات، کدهایی به شکل زیر خواهیم داشت.

@using System.Web.Optimization;


    
        
        @Page.Title - My ASP.NET Web Page

         @Styles.Render("~/Content/themes/base/css", "~/Content/css");

        

        @Scripts.Render("~/bundles/jquery",
            "~/bundles/jqueryui",
                     "~/bundles/modernizr");

        
    

با تغییرات صورت گرفته، CSS و جاوا اسکریپت به صورت Bundle تحویل داده می‌شوند. باندل‌ها را می‌توان در «نماها» (Views) با استفاده از متد Render ارجاع داد (Styles.Render برای CSS و Scripts.Render برای جاوا اسکریپت).

آموزش چارچوب توسعه تحت وب ASP.NET MVC
فیلم آموزش چارچوب توسعه تحت وب ASP.NET MVC در تم آف

کلیک کنید

پیکربندی پیش‌فرض برای صفحات وب، مولفه کامپایل را روی debug=true

 تنظیم می‌کند. تا وقتی که پیکربندی کامپایل به این صورت باشد، هیچ‌کدام از اَعمال باندلینگ یا کمینه‌سازی انجام نمی‌شوند. فایل Web.config را باز و ویژگی debug

در عناصر کامپایل را مطابق شکل زیر به false تغییر می‌دهیم:



  
    
  
  

Bundling و Minification در وب فرم ها

برای این منظور، یک برنامه جدید ASP.NET Web Forms با چارچوب دات نت ۴٫۵ ایجاد می‌کنیم.

ایجاد یک وب فرم جدید در ASP.NET

برنامه و پس از آن، ابزارهای توسعه‌دهنده IE یعنی Developer Tools را اجرا می‌کنیم. برای مشاهده فایل‌های جاوا اسکریپت، می‌توان زبانه Script را انتخاب و از دکمه Assets استفاده کرد.

زبانه Script در ابزار توسعه دهنده مرورگر
برای مشاهده تصویر در اندازه اصلی روی آن کلیک کنید

با انتخاب یکی از فایل‌های جاوا اسکریپت، محتویات آن در پنجره نمایش داده می‌شود. توجه داشته باشید که در اینجا از فایل‌های کامل (نسخه کمینه نشده) استفاده شده است.

ایجاد باندل های جی کوئری

jQuery، jQuery.UI و jQuery validation را به کلاس BundleConfig در پوشه App_Start اضافه کنید. کد کلاس به صورت زیر است.

using System.Web.Optimization;

public class BundleConfig
{
    public static void RegisterBundles(BundleCollection bundles)
    {
        bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
                    "~/Scripts/jquery-{version}.js"));

        bundles.Add(new ScriptBundle("~/bundles/jqueryui").Include(
                    "~/Scripts/jquery-ui-{version}.js"));

        bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
                    "~/Scripts/jquery.unobtrusive*",
                    "~/Scripts/jquery.validate*"));

        bundles.Add(new ScriptBundle("~/bundles/WebFormsJs").Include(
              "~/Scripts/WebForms/WebForms.js",
              "~/Scripts/WebForms/WebUIValidation.js",
              "~/Scripts/WebForms/MenuStandards.js",
              "~/Scripts/WebForms/Focus.js",
              "~/Scripts/WebForms/GridView.js",
              "~/Scripts/WebForms/DetailsView.js",
              "~/Scripts/WebForms/TreeView.js",
              "~/Scripts/WebForms/WebParts.js"));

        bundles.Add(new ScriptBundle("~/bundles/MsAjaxJs").Include(
            "~/Scripts/WebForms/MsAjax/MicrosoftAjax.js",
            "~/Scripts/WebForms/MsAjax/MicrosoftAjaxApplicationServices.js",
            "~/Scripts/WebForms/MsAjax/MicrosoftAjaxTimer.js",
            "~/Scripts/WebForms/MsAjax/MicrosoftAjaxWebForms.js"));

        bundles.Add(new ScriptBundle("~/bundles/modernizr").Include(
            "~/Scripts/modernizr-*"));
    }
}

ثبت باندل ها

«قالب‌ها» (Templates) کدی به صورت زیر در متد Application_Start (در فایل Global.asax) می‌سازند.

void Application_Start(object sender, EventArgs e)
{
    BundleConfig.RegisterBundles(BundleTable.Bundles);
    AuthConfig.RegisterOpenAuth();
}

ارجاع به باندل ها

همانطور که در کدهای زیر مشاهده می‌کنید، باندل‌های جی کوئری را باید به نشانه‌گذاری اضافه کنیم.

        
         
         
         
    

پس از آن، ارجاعیات اسکریپت jQuery را در تگ ScriptManager، همان‌گونه که در زیر نشان داده شده است، از حالت «توضیح» (Comment) خارج می‌کنیم.


    
--%>

باندل های CSS

فایل Bundle.config

 ، که حاوی نشانه‌گذاری‌هایی برای ایجاد باندل‌های سَبک‌های CSS است، را بررسی کنید.



  
    
  
  
    
    
    
    
    
    
    
    
    
    
    
    
  

همچنین می‌توانید باندل‌های سَبک‌ خود را به فایل Bundle.config

اضافه کنید. نشانه‌گذاری‌های زیر، ارجاعات مربوط به باندل‌های CSS و هچنین باندل‌های جاوا اسکریپت را نشان می‌دهند. توجه داشته باشید که می‌توانید چندین باندل را در یک فراخوانی، با استفاده از متد Render انجام دهید.



استفاده از Bundling و Minification در ASP.NET MVC

در این بخش، یک پروژه ASP.NET MVC، برای بررسی و امتحان باندلینگ و کمینه‌سازی می‌سازیم. پس قبل از هر چیز، یک پروژه جدید اینترنتی ASP.NET MVC با نام MvcBM

 و بدون تغییر هیچ یک از پیش‌فرض‌ها ایجاد می‌کنیم.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

فایل App_StartBundleConfig.cs

 را باز و متد RegisterBundles

را بررسی می‌کنیم. این متد برای ایجاد، «ثبت» (Register) و پیکربندی باندل‌ها استفاده می‌شود. کدهای زیر بخشی از متد RegisterBundles

را نشان می‌دهند.

public static void RegisterBundles(BundleCollection bundles)
{
     bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
                 "~/Scripts/jquery-{version}.js"));
         // Code removed for clarity.
}

یکی از اصطلاحات حوزه نرم‌افزار، «کاراکتر جانشین» (Wildcard) است که معمولا با یک کاراکتر تکی نشان داده می‌شود. مانند کاراکتر «ستاره» (*) که می‌تواند به عنوان جایگزینی برای تعدادی کاراکتر یا رشته‌ای خالی تفسیر شود. این مفهوم اغلب در جستجوی فایل استفاده می‌شود، که در این صورت، نیازی به نوشتن نام کامل آن نیست. مثلاً عبارت «a*e» می‌تواند شامل هر رشته‌ای باشد که با کاراکتر «a» آغاز و با «e» پایان یافته است (مانند apple).

کدهای بالا یک باندل جاوا اسکریپتی جدید به نام ~/bundles/jquery

می‌سازند که تمام فایل‌های مناسب (منظور، فایل‌های مناسبی نظیر اشکال‌زدایی یا کمینه‌سازی است و نه فایل‌های vsdoc.) در پوشه Scripts

و منطبق با کاراکتر جایگزین ~/Scripts/jquery-{version}.js

را شامل می‌شود. برای ASP.NET MVC، با پیکربندی دیباگ، فایل jquery-1.7.1.js

و در پیکربندی انتشار (Release)، jquery-1.7.1.min.js

به باندل اضافه خواهد شد.

فریم ورک Bundling از چندین قاعده اصلی پیروی می‌کند، که در ادامه شرح داده شده‌اند.

  • انتخاب فایل .min

    برای انتشار، زمانی که FileX.min.js

    و FileX.js

    وجود دارد.

  • نسخه غیر .min

      برای دیباگ کردن انتخاب می‌شود.

  • نادیده گرفتن فایل‌های -vsdoc

      (مانند jquery-1.7.1-vsdoc.js

    )، که فقط توسط محیط IntelliSense استفاده می‌شوند.

آموزش چارچوب توسعه تحت وب ASP.NET MVC
فیلم آموزش چارچوب توسعه تحت وب ASP.NET MVC در تم آف

کلیک کنید

«انطباقِ» (Matching) کاراکترِ جانشینِ {version}

که در بالا دیدیم، برای ایجاد خودکار یک باندل جی کوئری، با نسخه مناسب jQuery موجود در پوشه Scripts

شما استفاده می‌شود. در این مثال، استفاده از کاراکتر جانشین مزایای زیر را به همراه دارد:

  • به شما امکان می‌دهد تا از NuGet برای به‌روزرسانی کتابخانه jQuery به نسخه جدیدتر آن استفاده کنید. بدون اینکه نیاز به تغییر کدهای باندلینگ قبلی یا ارجاعیات jQuery در صفحات خود داشته باشید.
  • به طور خودکار، نسخه کامل را برای پیکربندی دیباگ، و نسخه .min

    را برای نسخه‌های انتشار انتخاب می‌کند.

استفاده از CDN

کدهای زیر باندل jQuery محلی را با یک باندل شبکه توزیع محتوای (CDN) جی کوئری، جایگزین می‌کند.

public static void RegisterBundles(BundleCollection bundles)
{
    //bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
    //            "~/Scripts/jquery-{version}.js"));

    bundles.UseCdn = true;   //enable CDN support

    //add link to jquery on the CDN
    var jqueryCdnPath = "https://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.7.1.min.js";

    bundles.Add(new ScriptBundle("~/bundles/jquery",
                jqueryCdnPath).Include(
                "~/Scripts/jquery-{version}.js"));

    // Code removed for clarity.
}

در کد بالا و در حالت انتشار، jQuery از CDN درخواست می‌شود و در حالت دیباگ، نسخه دیباگ jQuery به صورت محلی واکشی می‌شود. هنگام استفاده از CDN، باید یک ساز و کار «بازگشت» (Fallback) داشته باشیم، برای مواقعی که درخواست CDN با شکست مواجه می‌شود.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

تکه «نشانه‌گذاری» (Markup) زیر (از انتهای فایل Layout)، اسکریپت اضافه شده به درخواست jQuery، در مواقع خرابی CDN را نشان می‌دهد.



        @Scripts.Render("~/bundles/jquery")

         

        @RenderSection("scripts", required: false)
    

نحوه ایجاد باندل در ASP.NET MVC

متد Include

از کلاس Bundle

، آرایه‌ای از رشته‌ها را دریافت می‌کند. به این ترتیب که هر رشته نشان‌دهنده مسیری مجازی به منبع است.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

کد زیر از متد RegisterBundles

در فایل App_StartBundleConfig.cs

، چگونگی اضافه شدن چندین فایل به یک باندل را نشان می‌دهد:

bundles.Add(new StyleBundle("~/Content/themes/base/css").Include(
    "~/Content/themes/base/jquery.ui.core.css",
    "~/Content/themes/base/jquery.ui.resizable.css",
    "~/Content/themes/base/jquery.ui.selectable.css",
    "~/Content/themes/base/jquery.ui.accordion.css",
    "~/Content/themes/base/jquery.ui.autocomplete.css",
    "~/Content/themes/base/jquery.ui.button.css",
    "~/Content/themes/base/jquery.ui.dialog.css",
    "~/Content/themes/base/jquery.ui.slider.css",
    "~/Content/themes/base/jquery.ui.tabs.css",
    "~/Content/themes/base/jquery.ui.datepicker.css",
    "~/Content/themes/base/jquery.ui.progressbar.css",
    "~/Content/themes/base/jquery.ui.theme.css"));

متد IncludeDirectory

از کلاس Bundle

، برای افزودن همه فایل‌های موجود در یک فهرست (و در صورت تمایل همه زیر شاخه‌ها) استفاده می‌شود. منظور، همان فایل‌هایی است که با الگوی جستجو مطابقت دارند. این متد در کدهای زیر استفاده شده است.

public Bundle IncludeDirectory(
    string directoryVirtualPath,  // The Virtual Path for the directory.
    string searchPattern)         // The search pattern.

public Bundle IncludeDirectory(
    string directoryVirtualPath,  // The Virtual Path for the directory.
    string searchPattern,         // The search pattern.
    bool searchSubdirectories)    // true to search subdirectories.

باندل‌ها با استفاده از متد Render در Viewها ارجاع داده می‌شوند. نشانه‌گذاری زیر از فایل ViewsShared_Layout.cshtml

، نشان‌دهنده این است که viewهای پیش‌فرض پروژه اینترنتی ASP.NET، چگونه به باندل‌های CSS و جاوا اسکریپت اشاره می‌کنند.




    @* Markup removed for clarity.*@    
    @Styles.Render("~/Content/themes/base/css", "~/Content/css")
    @Scripts.Render("~/bundles/modernizr")


    @* Markup removed for clarity.*@
   
   @Scripts.Render("~/bundles/jquery")
   @RenderSection("scripts", required: false)

توجه داشته باشید که متدهای Render، آرایه‌ای از رشته‌ها را می‌گیرند، بنابراین می‌توانید چندین باندل را با تنها یک خط کد اضافه کنید. ما معمولاً از متدهای Render استفاده می‌کنیم. یعنی متدهایی که HTML لازم را برای ارجاع به assetها ایجاد می‌کنند.

همچنین می‌توان از متد URL هم برای ایجاد URL به asset، بدون نشانه‌گذاری مورد نیاز برای ارجاع به assetها استفاده کرد. فرض کنید می‌خواهیم از ویژگی جدید HTML5 یعنی async استفاده کنیم. کدهای زیر، نحوه ارجاع به modernizr (نام کتابخانه‌ای جاوا اسکریپتی) را با استفاده از روش URL نشان می‌دهند.


    @*Markup removed for clarity*@
    
    @ViewBag.Title - MVC 4 B/M
    
    
    @Styles.Render("~/Content/css")

   @* @Scripts.Render("~/bundles/modernizr")*@

    

استفاده از کاراکتر جایگزین «*» برای انتخاب فایل ها

مسیر مجازی مشخص شده در متد Include

و الگوی جستجویی که در متد IncludeDirectory

وجود دارد، می‌تواند یک کاراکتر جایگزین «*» را به عنوان پیشوند یا پسوند در آخرین بخش مسیر بپذیرد.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

توجه داشته باشید که رشته جستجو به بزرگ و کوچک بودن حروف حساس نیست (Case Insensitive است). این متد همچنین، امکانی برای جستجو در زیر شاخه‌ها را دارد. پروژه‌ای را با فایل‌های جاوا اسکریپت زیر در نظر بگیرید:

  • ScriptsCommonAddAltToImg.js
  • ScriptsCommonToggleDiv.js
  • ScriptsCommonToggleImg.js
  • ScriptsCommonSub1ToggleLinks.js

جدول زیر فایل‌هایی را نشان می‌دهد که با استفاده از کاراکتر جایگزین به یک بسته اضافه شده است.

فایل‌های افزوده شده یا استثناهای رخ داده دستور فراخوانی

AddAltToImg.js

ToggleDiv.js

ToggleImg.js

Include(“~/Scripts/Common/*.js”)

استثنای «الگوی نامعتبر».

استفاده از کاراکتر جایگزین فقط روی پیشوند و پسوند مجاز است.

Include(“~/Scripts/Common/T*.js”)

استثنای «الگوی نامعتبر».

استفاده از تنها یک کاراکتر جایگزین مجاز است.

Include(“~/Scripts/Common/*og.*”)

ToggleDiv.js

ToggleImg.js

Include(“~/Scripts/Common/T*”)

استثنای «الگوی نامعتبر».

بخش اصلی کاراکتر معتبر نیست.

Include(“~/Scripts/Common/*”)

ToggleDiv.js

ToggleImg.js

IncludeDirectory(“~/Scripts/Common”, “T*”)

ToggleDiv.js

ToggleImg.js

ToggleLinks.js

IncludeDirectory(“~/Scripts/Common”, “T*”, true)

اختصاص هر فایل به یک باندل، نسبت به بارگذاری کاراکتر جایگزین فایل‌ها، معمولا ترجیح داده می‌شود، در زیر دلایلی برای این موضوع بیان شده است:

  • افزودن اسکریپت‌ها توسط پیش‌فرض‌هایی که کاراکتر جایگزین در نظر می‌گیرد (برای بارگیری آنها به ترتیب حروف الفبا عمل می‌کند)، معمولا آن چیزی نیست که می‌خواهیم. فایل‌های CSS و جاوا اسکریپت اغلب باید به ترتیب خاصی (غیر الفبایی) اضافه شوند. شما می‌توانید این ریسک را با افزودن یک پیاده‌سازی سفارشی IBundleOrderer کاهش دهید. به عنوان مثال، ممکن است در آینده، assetهای جدیدی را به پوشه‌ای اضافه کنید و نیاز باشد که پیاده‌سازی IBundleOrderer خود را نیز اصلاح کنید.
  • فایل‌های خاصی از نما، که با استفاده از بارگذاری کاراکتر جایگزین به فهرست اضافه شده‌اند را می‌توان در همه نماهایی که به آن بسته ارجاع می‌دهند اضافه کرد. اگر اسکریپت View خاصی، به یک باندل اضافه شود، ممکن است یک خطای جاوا اسکریپتی را در سایر نماهایی که به باندل ارجاع می‌دهند، دریافت کنید.
  • فایل‌های CSS که فایل‌های دیگر را import می‌کنند، منجر به بارگذاری دوباره فایل‌هایی می‌شوند که یک‌بار ایمپورت شده‌اند. به عنوان مثال، کدهای زیر، باندلی ایجاد می‌کند که اکثر فایل‌های CSS قالب jQuery UI، دو مرتبه بارگذاری شده‌اند.
bundles.Add(new StyleBundle("~/jQueryUI/themes/baseAll")
    .IncludeDirectory("~/Content/themes/base", "*.css"));

انتخابگر کاراکتر جایگزین *.css

، هر فایل CSS، از جمله فایل Contentthemesbasejquery.ui.all.css

را به پوشه وارد می‌کند. فایل jquery.ui.all.css

نیز سایر فایل‌های CSS را وارد می‌کند.

نهان سازی باندل یا Bundle Caching چیست؟

باندل‌ها، «سرآیند» (Header) انقضای HTTP را برابر با یک سال از زمان ایجاد باندل تنظیم می‌کنند. با رفتن به صفحه‌ای که قبلاً مشاهده کرده‌اید، Fiddler نشان می‌دهد که IE درخواست مشروطی را برای باندل‌ها نمی‌سازد، یعنی هیچ درخواستِ HTTP GET، از IE برای باندل‌‌ها و هیچ پاسخِ HTTP 304، از سمت سرور وجود ندارد.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

شما با زدن کلید F5 می‌توانید IE را مجبور کنید تا برای هر بسته یک درخواست شرطی ایجاد کند. (یعنی منجر به پاسخ HTTP 304 برای هر باندل شود). شما همچنین می‌توانید رفرش کاملی را با کلیدهای Ctrl+F5 داشته باشید (که پاسخ HTTP 200 برای هر باندل را تولید می‌کند). تصویر زیر زبانه «نهان‌سازی» (Caching) را در صفحه پاسخ Fiddler نشان می‌دهد.

نهان سازی Bundling در ASP.NET MVC

درخواستی که در ادامه آمده، مربوط به باندل AllMyScripts است و یک جفتِ «رشته پرس و جو» (Query String) را شامل می‌شود.

http://localhost/MvcBM_time/bundles/AllMyScripts?v=r0sLDicvP58AIXN_mc3QdyVvVj5euZNzdsa2N1PKvb81

رشته پرس و جوی v

، توکن مقداری شامل شناسه‌ای منحصر به فرد دارد که برای نهان‌سازی به‌کار می‌رود. تا زمانی که باندل تغییر نکند، برنامه ASP.NET با استفاده از این توکن، باندل AllMyScripts را درخواست می‌کند. هر زمانی که فایلی در باندل دچار تغییر شود، چارچوب بهینه‌سازی ASP.NET، توکن جدیدی ایجاد خواهد کرد و با تضمین اینکه که درخواست‌های مرورگر در مورد این باندل، همیشه آخرین (جدیدترین نسخه) را دریافت می‌کند.

اگر Developer Tools مربوط به IE9 (کلید میانبر F12) را اجرا کنید و به صفحه‌ای که قبلاً بارگذاری شده است بروید، IE به اشتباه درخواست‌های GET مشروطی را نشان می‌دهد که برای هر باندل و سروری که HTTP 304 را بر می‌گرداند، ساخته شده است.

باندلینگ مواردی همچون LESS ،‌CoffeeScript ،SCSS و Sass

چارچوب باندلینگ و کمینه‌سازی، ساز و کاری برای پردازش زبان‌های میانی مانند SCSS ،Sass ،LESS یا Coffeescript را فراهم می‌کند و تغییر فرم‌هایی (تبدیل‌هایی) مانند کمینه‌سازی در باندل به دست آمده را اعمال می‌کند.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

برای مثال، به منظور اضافه کردن فایل‌های ‎.less‎ به پروژه MVC خود باید موارد زیر را انجام دهیم.

  • ابتدا یک پوشه برای محتوای LESS ایجاد کنید. مثالِ زیر از پوشه ContentMyLess

    استفاده می‌کند. سپس بسته ناگت مربوط به dotless (یعنی‎ .less

    ) را به پروژه خود اضافه کنید.

مثالی از باندلینگ LESS در ASP.NET MVC
  • در ادامه، لازم است که کلاس جدیدی اضافه کنیم تا رابط IBundleTransform

    را پیاده سازی کند. برای تبدیل‎ .less

    ، کدهای زیر را به پروژه اضافه می‌کنیم.

using System.Web.Optimization;

public class LessTransform : IBundleTransform
{
    public void Process(BundleContext context, BundleResponse response)
    {
        response.Content = dotless.Core.Less.Parse(response.Content);
        response.ContentType = "text/css";
    }
}
  • با استفاده از تبدیل‌های CssMinify

    و LessTransform

    ، باندلی از فایل‌های LESS ایجاد می‌کنیم و کد زیر به متد RegisterBundles

    در فایل App_StartBundleConfig.cs

    اضافه می‌شود.

var lessBundle = new Bundle("~/My/Less").IncludeDirectory("~/My", "*.less");
lessBundle.Transforms.Add(new LessTransform());
lessBundle.Transforms.Add(new CssMinify());
bundles.Add(lessBundle);

در پایان نیز، لازم است تا کد زیر را به همه Viewهایی اضافه کنیم که باندل LESS را فراخوانی می‌کنند.

@Styles.Render("~/My/Less");

ملاحظاتی در مورد باندل ها در ASP.NET MVC

یکی از مواردی که بهتر است هنگام ایجاد باندل‌ها رعایت شود، این است که واژه «bundle» را به عنوان پیشوند در نام‌گذاری آنها به‌کار ببریم. این قاعده از رخ دادن «تداخل در آدرس‌دهی» (Routing Conflict) جلوگیری می‌کند.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

هنگامی‌که یکی از فایل‌های موجود در باندل را به‌روز می‌کنید، توکنی جدید برای پارامترِ «رشته پرس و جویِ» (Query String) باندل ایجاد می‌شود و دفعه بعد که کلاینت صفحه حاوی باندل را درخواست می‌کند، باندل باید کامل دانلود شود. در نشانه‌گذاری سنتی (پیش از این) که هر asset به‌صورت جداگانه فهرست می‌شود، فقط فایل تغییر یافته دانلود می‌شد. بنابراین assetهایی که زود به زود تغییر می‌کنند ممکن است کاندید‌های مناسبی برای باندلینگ نباشند.

Bundling و Minification در ASP.NET MVC، عمدتاً زمان بارگذاری درخواست صفحه اول را بهبود می‌بخشند. پس از درخواست یک صفحه وب از سرور، مرورگر، assetها (جاوا اسکریپت، CSS و تصاویر) را نهان‌سازی می‌کند، بنابراین هنگام درخواست همان صفحه یا صفحاتی در همان سایت که assetهای مشابهی را درخواست می‌کنند، باندلینگ و کمینه‌سازی هیچ بهبودی را در عملکرد برنامه ایجاد نمی‌کنند.

اگر سرآیند مربوط به انقضا را در assetهای خود به درستی تنظیم نکنید، و همچنین از باندلینگ و کمینه‌سازی نیز استفاده نشود، اکتشافات مربوط به تازه‌سازی مرورگرها، پس از چند روز assetهای قدیمی‌ را علامت‌گذاری می‌کنند و برای هر asset به درخواست اعتبارسنجی مجدد نیاز خواهند داشت.

محدودیت مرورگر در ۶ اتصال همزمان برای هر نام میزبان را می‌توان با استفاده از CDN کاهش داد. از آنجایی که CDN، نام میزبان متفاوتی نسبت به سایت میزبان شما دارد، درخواست‌های مربوط به asset از CDN، در محدودیت ۶ اتصال همزمان به محیط میزبانی شما حساب نمی‌شوند. یک CDN همچنین می‌تواند مزیت‌های نهان‌سازی بسته‌های رایج و نهان‌سازی لبه را نیز فراهم کند.

باندل‌ها باید بر اساس صفحاتی که به آنها نیاز دارند قسمت‌بندی شوند. به عنوان مثال، الگوی پیش‌فرض ASP.NET MVC برای یک اپلیکیشن اینترنتی، یک باندل اعتبارسنجی jQuery جدا از jQuery ایجاد می‌کند.

سوالات متداول

در این قسمت، تعدادی از سوالات رایج و پاسخ آن‌ها را در پیرامون Bundling و Minification، با هم مرور می‌کنیم.

آموزش استفاده از Bundling و Minification در ASP.NET MVC  – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی
فیلم آموزش استفاده از Bundling و Minification در ASP.NET MVC – بایندینگ و مینی فیکیشن در ای اس پی دات نت ام وی سی در تم آف

کلیک کنید

قابلیت‌های Bundling و Minification در ASP.NET MVC را چگونه فعال کنیم؟

با تنظیم مقدار ویژگی debug در مولفه کامپایلِ موجود در فایل Web.config، می‌توان این قابلیت‌ها را فعال یا غیر فعال کرد. اگر در این فایلِ XML، ویژگی debug برابر با true باشد، باندلینگ و مینیفیکیشن، غیرفعال‌اند. در مقابل اگر مقدار debug برابر با false باشد، این دو ویژگی قابل استفاده هستند.

Bundling و Minification در ASP.NET MVC چه تفاوتی با هم دارند؟

تکنیک‌های باندلینگ و مینیفیکیشن، با هدف بهبود عملکرد صفحات وب و  افزایش سرعت بارگذاری آن‌ها به‌کار می‌روند. به طور خلاصه در باندلینگ، چندین فایل در قالب یک فایل با هم ادغام می‌شوند. مینیفیکیشن نیز بهینه‌سازی‌هایی را به منظور کم‌حجم‌تر شدن اسکریپت‌ها و کدهای CSS، روی آن‌ها اعمال می‌کند.

آموزش چارچوب توسعه تحت وب ASP.NET MVC
فیلم آموزش چارچوب توسعه تحت وب ASP.NET MVC در تم آف

کلیک کنید

مزیت باندلینگ اسکریپت‌های JS در قالب یک فایل چیست؟

باندلینگ جاوا اسکریپت، تکنیکی برای بهینه‌سازی آن است که می‌تواند تعداد درخواست‌هایی که برای دریافت این فایل‌ها به سرور ارسال می‌شوند را کاهش دهد. Bundling این کار را با ادغام چندین فایل جاوا اسکریپت در قالب یک فایل، انجام می‌دهد تا تعداد درخواست‌های صفحه کاهش پیدا کنند.

سخن پایانی

با هر نسخه جدیدی که از چارچوب ASP.NET MVC منتشر می‌شود، ویژگی‌ها و امکانات بیشتر و بهتری به آن افزوده می‌شود. Bundling و Minification در ASP.NET MVC، فرایندهایی ضروری محسوب می‌شوند که باید در هر برنامه وبی که می‌سازیم، مورد استفاده قرار گیرند.

مجموعه آموزش برنامه نویسی ASP.NET
فیلم مجموعه آموزش برنامه نویسی ASP.NET در تم آف

کلیک کنید

منظور، همان برنامه‌هایی است که به منابع مهمی از جاوا اسکریپت و CSS متکی‌اند و نیاز داریم تا عملکرد بهتری را ارائه دهند. خوشبختانه، در طراحی این فرایندها، ویژگی‌هایی نظیر سفارشی‌سازی (Customization) و توسعه‌پذیری (Extensibility) نیز مدنظر قرار گرفته است. با کمی تلاش، Minification را نیز بر اساس اینکه برنامه وب ما در حالت دیباگ اجرا می‌شود یا خیر، به آسانی می‌توان مورد استفاده قرار داد.

ارسال پاسخ

This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.