在我们的应用程序中,我们有几个以移动格式提供的页面,但并非所有页面都可用.
所以我决定按照那个教程:A Better Way to Add Mobile Pages运行良好.
当用户使用移动设备时,如果移动视图可用,则会呈现移动视图,否则将显示移动视图的桌面版本.
但是我的布局有问题.我的桌面布局和我的移动布局是不同的,所以当移动页面呈现时,我想使用我的移动布局,当显示桌面版本时,即使用户在移动设备上,我也想使用我的桌面布局.
我将以下代码添加到我的应用程序控制器(我还在此链接A Better Way to Add Mobile Pages中添加了代码)以检测用户是否可移动并相应地更改布局:
layout :determine_layout
def mobile_device?
if session[:mobile_override]
session[:mobile_override] == "1"
else
# Season this regexp to taste. I prefer to treat iPad as non-mobile.
(request.user_agent =~ /(iPhone|iPod|Android|webOS|Mobile)/) && (request.user_agent !~ /iPad/)
end
end
helper_method :mobile_device?
def determine_layout
if mobile_device?
"mobile"
else
"application"
end
end
但是,此代码的问题在于,即使页面在view_mobiles中不可用,它也会尝试显示移动布局,因为我正在检查移动设备而不是移动页面.
如何根据渲染的视图确定布局?或者如果视图存在?
我的移动视图位于view_mobiles文件夹中.我想检查是否呈现移动视图而不是移动设备并显示相应的布局.
那可能吗 ?
非常感谢,
最佳答案 好的,这就是我最终找到的以及我如何使用它设计:
我现在可以在与常规视图相同的文件夹中创建移动视图,如果移动视图不存在,它将回退到常规视图.
以下是使一切正常工作所需的两个链接:
Mobile Format Fallback to default views if mobile view is missing