What is ViewStart Page in MVC?
This page is used to make sure common layout page will be used for multiple views. Code written in this file will be executed first when application is being loaded.
Explain the methods used to render the views in MVC?
Below are the methods used to render the views from action -
View() — To return the view from action.
PartialView() — To return the partial view from action.
RedirectToAction() — To Redirect to different action which can be in same controller or in different controller.
Redirect() — Similar to “Response.Redirect()” in webforms, used to redirect to specified URL.
RedirectToRoute() — Redirect to action from the specified URL but URL in the route table has been matched.
What are the sub types of ActionResult?
ActionResult is used to represent the action method result. Below are the subtypes of ActionResult –
ViewResult
PartialViewResult
RedirectToRouteResult
RedirectResult
JavascriptResult
JSONResult
FileResult
HTTPStatusCodeResult
What are Non Action methods in MVC?
In MVC all public methods have been treated as Actions. So if you are creating a method and if you do not want to use it as an action method then the method has to be decorated with “NonAction” attribute as shown below –
[NonAction]
public void TestMethod()
{
// Method logic
}
How to change the action name in MVC?
“ActionName” attribute can be used for changing the action name. Below is the sample code snippet to demonstrate more –
[ActionName(“TestActionNew”)]
public ActionResult TestAction()
{
return View();
}
So in the above code snippet “TestAction” is the original action name and in “ActionName” attribute, name — “TestActionNew” is given. So the caller of this action method will use the name “TestActionNew” to call this action.
What is Html.RenderPartial?
Result of the method — “RenderPartial” is directly written to the HTML response. This method does not return anything (void). This method also does not depend on action methods. RenderPartial() method calls “Write()” internally and we have to make sure that “RenderPartial” method is enclosed in the bracket. Below is the sample code snippet –@{Html.RenderPartial(“TestPartialView”); }
What are the components required to create a route in MVC?
Name — This is the name of the route.
URL Pattern — Placeholders will be given to match the request URL pattern.
Defaults –When loading the application which controller, action to be loaded along with the parameter.
Why to use “{resource}.axd/{*pathInfo}” in routing in MVC?
Using this default route — {resource}.axd/{*pathInfo}, we can prevent the requests for the web resources files like — WebResource.axd or ScriptResource.axd from passing to a controller.
Can we add constraints to the route? If yes, explain how we can do it?
Yes we can add constraints to route in following ways –
Using Regular Expressions
Using object which implements interface — IRouteConstraint.
What are the possible Razor view extensions?
Below are the two types of extensions razor view can have –
.cshtml — In C# programming language this extension will be used.
.vbhtml — In VB programming language this extension will be used.
What is PartialView in MVC?
PartialView is similar to UserControls in traditional web forms. For re-usability purpose partial views are used. Since it’s been shared with multiple views these are kept in shared folder. Partial Views can be rendered in following ways –
Html.Partial()
Html.RenderPartial().
This page is used to make sure common layout page will be used for multiple views. Code written in this file will be executed first when application is being loaded.
Explain the methods used to render the views in MVC?
Below are the methods used to render the views from action -
View() — To return the view from action.
PartialView() — To return the partial view from action.
RedirectToAction() — To Redirect to different action which can be in same controller or in different controller.
Redirect() — Similar to “Response.Redirect()” in webforms, used to redirect to specified URL.
RedirectToRoute() — Redirect to action from the specified URL but URL in the route table has been matched.
What are the sub types of ActionResult?
ActionResult is used to represent the action method result. Below are the subtypes of ActionResult –
ViewResult
PartialViewResult
RedirectToRouteResult
RedirectResult
JavascriptResult
JSONResult
FileResult
HTTPStatusCodeResult
ATOS Frequently Asked ASP.NET MVC Interview Questions Answers |
What are Non Action methods in MVC?
In MVC all public methods have been treated as Actions. So if you are creating a method and if you do not want to use it as an action method then the method has to be decorated with “NonAction” attribute as shown below –
[NonAction]
public void TestMethod()
{
// Method logic
}
How to change the action name in MVC?
“ActionName” attribute can be used for changing the action name. Below is the sample code snippet to demonstrate more –
[ActionName(“TestActionNew”)]
public ActionResult TestAction()
{
return View();
}
So in the above code snippet “TestAction” is the original action name and in “ActionName” attribute, name — “TestActionNew” is given. So the caller of this action method will use the name “TestActionNew” to call this action.
Result of the method — “RenderPartial” is directly written to the HTML response. This method does not return anything (void). This method also does not depend on action methods. RenderPartial() method calls “Write()” internally and we have to make sure that “RenderPartial” method is enclosed in the bracket. Below is the sample code snippet –@{Html.RenderPartial(“TestPartialView”); }
What are the components required to create a route in MVC?
Name — This is the name of the route.
URL Pattern — Placeholders will be given to match the request URL pattern.
Defaults –When loading the application which controller, action to be loaded along with the parameter.
Why to use “{resource}.axd/{*pathInfo}” in routing in MVC?
Using this default route — {resource}.axd/{*pathInfo}, we can prevent the requests for the web resources files like — WebResource.axd or ScriptResource.axd from passing to a controller.
Can we add constraints to the route? If yes, explain how we can do it?
Yes we can add constraints to route in following ways –
Using Regular Expressions
Using object which implements interface — IRouteConstraint.
What are the possible Razor view extensions?
Below are the two types of extensions razor view can have –
.cshtml — In C# programming language this extension will be used.
.vbhtml — In VB programming language this extension will be used.
What is PartialView in MVC?
PartialView is similar to UserControls in traditional web forms. For re-usability purpose partial views are used. Since it’s been shared with multiple views these are kept in shared folder. Partial Views can be rendered in following ways –
Html.Partial()
Html.RenderPartial().
What Are Actions In Asp.net Mvc?
Actions are the methods in Controller class which is responsible for returning the view or json data. Action will mainly have return type : "ActionResult" and it will be invoked from method : "InvokeAction()" called by controller.
What Is Attribute Routing In Asp.net Mvc?
ASP.NET Web API supports this type routing. This is introduced in ASP.Net MVC5. In this type of routing, attributes are being used to define the routes. This type of routing gives more control over classic URI Routing.
Attribute Routing can be defined at controller level or at Action level like
[Route("{action = TestCategoryList}")] - Controller Level
[Route("customers/{TestCategoryId:int:min(10)}")] - Action Level
How To Enable Attribute Routing?
Just add @Model.CustomerName the method : "MapASP.Net MVCAttributeRoutes()" to enable attribute routing as shown below
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
//enabling attribute routing
routes.MapASP.Net MVCAttributeRoutes();
//convention-based routing
routes.MapRoute
(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Customer", action = "GetCustomerList", id = UrlParameter.Optional }
);
}
What Are The Options Can Be Configured In Ajax Helpers?
Below are the options in AJAX helpers
Url : This is the request URL.
Confirm : This is used to specify the message which is to be displayed in confirm box.
OnBegin : Javascript method name to be given here and this will be called before the AJAX request.
OnComplete : Javascript method name to be given here and this will be called at the end of AJAX request.
OnSuccess - Javascript method name to be given here and this will be called when AJAX request is successful.
OnFailure - Javascript method name to be given here and this will be called when AJAX request is failed.
UpdateTargetId : Target element which is populated from the action returning HTML.
What Is Layout In Asp.net Mvc?
Layout pages are similar to master pages in traditional web forms. This is used to set the common look across multiple pages. In each child page we can find : /p>
@{
Layout = "~/Views/Shared/TestLayout1.cshtml";
} This indicates child page uses TestLayout page as it's master page.
Explain Json Binding?
JavaScript Object Notation (JSON) binding support started from ASP.Net MVC3 onwards via the new JsonValueProviderFactory, which allows the action methods to accept and model-bind data in JSON format. This is useful in Ajax scenarios like client templates and data binding that need to post data back to the server.
Explain Dependency Resolution?
Dependency Resolver again has been introduced in ASP.Net MVC3 and it is greatly simplified the use of dependency injection in your applications. This turn to be easier and useful for decoupling the application components and making them easier to test and more configurable.
Explain Bundle.config In Asp.net Mvc5?
"BundleConfig.cs" in ASP.Net MVC5 is used to register the bundles by the bundling and minification system. Many bundles are added by default including jQuery libraries like - jquery.validate, Modernizr, and default CSS references.
How Route Table Has Been Created In Asp.net Asp.net Mvc?
Method : "RegisterRoutes()" is used for registering the routes which will be added in "Application_Start()" method of global.asax file, which is fired when the application is loaded or started.
Which Are The Important Namespaces Used In Asp.net Mvc?
Below are the important namespaces used in ASP.Net MVC
System.Web.ASP.Net MVC
System.Web.ASP.Net MVC.Ajax
System.Web.ASP.Net MVC.Html
System.Web.ASP.Net MVC.Async
What Is Viewdata?
Viewdata contains the key, value pairs as dictionary and this is derived from class : "ViewDataDictionary". In action method we are setting the value for viewdata and in view the value will be fetched by typecasting.
What Is The Difference Between Viewbag And Viewdata In Asp.net Mvc?
ViewBag is a wrapper around ViewData, which allows to create dynamic properties. Advantage of viewbag over viewdata will be : In ViewBag no need to typecast the objects as in ViewData. ViewBag will take advantage of dynamic keyword which is introduced in version 4.0. But before using ViewBag we have to keep in mind that ViewBag is slower than ViewData.
Explain Tempdata In Asp.net Mvc?
TempData is again a key, value pair as ViewData. This is derived from "TempDataDictionary" class. TempData is used when the data is to be used in two consecutive requests, this could be between the actions or between the controllers. This requires typecasting in view.
What Are Html Helpers In Asp.net Mvc?
HTML Helpers are like controls in traditional web forms. But HTML helpers are more lightweight compared to web controls as it does not hold viewstate and events. HTML Helpers returns the HTML string which can be directly rendered to HTML page. Custom HTML Helpers also can be created by overriding "HtmlHelper" class.
How To Use Jquery Plugins In Asp.net Mvc Validation?
We can use dataannotations for validation in ASP.Net MVC. If we want to use validation during runtime using Jquery then we can use Jquery plugins for validation.
Eg
If validation is to be done on customer name textbox then we can do as
$('#CustomerName').rules("add", {
required: true,
minlength: 2,
messages: {
required: "Please enter name",
minlength: "Minimum length is 2"
}
});
How We Can Multiple Submit Buttons In Asp.net Mvc?
Below is the scenario and the solution to solve multiple submit buttons issue. Scenario
@using (Html.BeginForm("MyTestAction","MyTestController")
{
<input type="submit" value="MySave" />
<input type="submit" value="MyEdit" />
} Solution
Public ActionResult MyTestAction(string submit) //submit will have value either "MySave" or "MyEdit"
{
// Write code here
}
Actions are the methods in Controller class which is responsible for returning the view or json data. Action will mainly have return type : "ActionResult" and it will be invoked from method : "InvokeAction()" called by controller.
What Is Attribute Routing In Asp.net Mvc?
ASP.NET Web API supports this type routing. This is introduced in ASP.Net MVC5. In this type of routing, attributes are being used to define the routes. This type of routing gives more control over classic URI Routing.
Attribute Routing can be defined at controller level or at Action level like
[Route("{action = TestCategoryList}")] - Controller Level
[Route("customers/{TestCategoryId:int:min(10)}")] - Action Level
How To Enable Attribute Routing?
Just add @Model.CustomerName the method : "MapASP.Net MVCAttributeRoutes()" to enable attribute routing as shown below
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
//enabling attribute routing
routes.MapASP.Net MVCAttributeRoutes();
//convention-based routing
routes.MapRoute
(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Customer", action = "GetCustomerList", id = UrlParameter.Optional }
);
}
What Are The Options Can Be Configured In Ajax Helpers?
Below are the options in AJAX helpers
Url : This is the request URL.
Confirm : This is used to specify the message which is to be displayed in confirm box.
OnBegin : Javascript method name to be given here and this will be called before the AJAX request.
OnComplete : Javascript method name to be given here and this will be called at the end of AJAX request.
OnSuccess - Javascript method name to be given here and this will be called when AJAX request is successful.
OnFailure - Javascript method name to be given here and this will be called when AJAX request is failed.
UpdateTargetId : Target element which is populated from the action returning HTML.
What Is Layout In Asp.net Mvc?
Layout pages are similar to master pages in traditional web forms. This is used to set the common look across multiple pages. In each child page we can find : /p>
@{
Layout = "~/Views/Shared/TestLayout1.cshtml";
} This indicates child page uses TestLayout page as it's master page.
Explain Json Binding?
JavaScript Object Notation (JSON) binding support started from ASP.Net MVC3 onwards via the new JsonValueProviderFactory, which allows the action methods to accept and model-bind data in JSON format. This is useful in Ajax scenarios like client templates and data binding that need to post data back to the server.
Explain Dependency Resolution?
Dependency Resolver again has been introduced in ASP.Net MVC3 and it is greatly simplified the use of dependency injection in your applications. This turn to be easier and useful for decoupling the application components and making them easier to test and more configurable.
Explain Bundle.config In Asp.net Mvc5?
"BundleConfig.cs" in ASP.Net MVC5 is used to register the bundles by the bundling and minification system. Many bundles are added by default including jQuery libraries like - jquery.validate, Modernizr, and default CSS references.
How Route Table Has Been Created In Asp.net Asp.net Mvc?
Method : "RegisterRoutes()" is used for registering the routes which will be added in "Application_Start()" method of global.asax file, which is fired when the application is loaded or started.
Which Are The Important Namespaces Used In Asp.net Mvc?
Below are the important namespaces used in ASP.Net MVC
System.Web.ASP.Net MVC
System.Web.ASP.Net MVC.Ajax
System.Web.ASP.Net MVC.Html
System.Web.ASP.Net MVC.Async
What Is Viewdata?
Viewdata contains the key, value pairs as dictionary and this is derived from class : "ViewDataDictionary". In action method we are setting the value for viewdata and in view the value will be fetched by typecasting.
What Is The Difference Between Viewbag And Viewdata In Asp.net Mvc?
ViewBag is a wrapper around ViewData, which allows to create dynamic properties. Advantage of viewbag over viewdata will be : In ViewBag no need to typecast the objects as in ViewData. ViewBag will take advantage of dynamic keyword which is introduced in version 4.0. But before using ViewBag we have to keep in mind that ViewBag is slower than ViewData.
Explain Tempdata In Asp.net Mvc?
TempData is again a key, value pair as ViewData. This is derived from "TempDataDictionary" class. TempData is used when the data is to be used in two consecutive requests, this could be between the actions or between the controllers. This requires typecasting in view.
What Are Html Helpers In Asp.net Mvc?
HTML Helpers are like controls in traditional web forms. But HTML helpers are more lightweight compared to web controls as it does not hold viewstate and events. HTML Helpers returns the HTML string which can be directly rendered to HTML page. Custom HTML Helpers also can be created by overriding "HtmlHelper" class.
How To Use Jquery Plugins In Asp.net Mvc Validation?
We can use dataannotations for validation in ASP.Net MVC. If we want to use validation during runtime using Jquery then we can use Jquery plugins for validation.
Eg
If validation is to be done on customer name textbox then we can do as
$('#CustomerName').rules("add", {
required: true,
minlength: 2,
messages: {
required: "Please enter name",
minlength: "Minimum length is 2"
}
});
How We Can Multiple Submit Buttons In Asp.net Mvc?
Below is the scenario and the solution to solve multiple submit buttons issue. Scenario
@using (Html.BeginForm("MyTestAction","MyTestController")
{
<input type="submit" value="MySave" />
<input type="submit" value="MyEdit" />
} Solution
Public ActionResult MyTestAction(string submit) //submit will have value either "MySave" or "MyEdit"
{
// Write code here
}
Post a Comment