你可以通過創建移動瀏覽器一個母版(~/Views/Shared/Site.Mobile.Master
)開始:
<%@ Master Language="C#" Inherits="System.Web.Mvc.ViewMasterPage" %>
<!DOCTYPE html>
<html lang="en">
<head runat="server">
<meta charset="utf-8" />
<title></title>
</head>
<body>
This is the mobile master page
<asp:ContentPlaceHolder ID="MainContent" runat="server" />
</body>
</html>
,然後有AA移動視圖(~/Views/Home/Index.Mobile.aspx
)將要使用該母版:
<%@ Page
Language="C#"
MasterPageFile="~/Views/Shared/Site.Mobile.Master"
Inherits="System.Web.Mvc.ViewPage"
%>
<asp:Content ID="indexContent" ContentPlaceHolderID="MainContent" runat="server">
This is the mobile view
</asp:Content>
好吧,現在剩下的就是將顯示模式插入你的Application_Start
:
Func<HttpContextBase, bool> contextCheckDelegate = ctx =>
{
// Here you could use the ctx variable which represents the HttpContextBase
// in order to test the UserAgent of the Request and decide whether it is coming
// from a mobile device or not and return true or false respectively which is what
// will determine if your .Mobile masterpage and view will be used for this request
if (IsMobile)
{
return true;
}
return false;
};
DefaultDisplayMode mobileMode = new DefaultDisplayMode("Mobile");
mobileMode.ContextCondition = contextCheckDelegate;
DisplayModeProvider.Instance.Modes.Insert(0, mobileMode);
您當然可以擁有更多特定的移動視圖,例如iPhone,iPad,......您只需調整委託人內部正在檢查用戶代理的情況。
完美!這解決了我的問題。 – MaX 2013-02-10 01:50:02