The code you see rendering css and scripts on your _Layout.cshtml
page (i.e. @Scripts.Render("~/bundles/modernizr")
) is called bundling. Check out some info here: http://www.asp.net/mvc/tutorials/mvc-4/bundling-and-minification
So, to add jQueryUI you would do the following:
In your Global.asax.cs file you should see a number of registrations:
BundleConfig.RegisterBundles(BundleTable.Bundles);
This goes to the BundleConfig
class which registers any bundles. For jQueryUI you could do the following:
bundles.Add(new ScriptBundle("~/bundles/jqueryui").Include(
"~/Scripts/jquery-ui-{version}.js"));
This is creating a new script bundle called ~/bundles/jqueryui
.
Then it can be added to your layout page by doing this:
@Scripts.Render("~/bundles/jqueryui")
Then you'll do the same for 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"));
and add it with
@Styles.Render("~/Content/themes/base/css")
Note:
- In MVC4, a non-empty project already has jQuery set up. For an empty project you would have to add it yourself. Not 100% sure about the new MVC 5.
- You can install jQueryUi from NuGet, but the official package doesn't add this bundling stuff.
- You could just do the old fashioned referencing of you css and js files (e.g.
<script language="JavaScript" src="~/Scripts/jQuery.ui.1.8.2.js" />
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…