Linking to Other Pages and Resources

本文介绍了Rails框架中用于创建链接、按钮、图片标签及邮件链接的方法,如link_to、button_to、image_tag等,并展示了如何利用这些方法来增强应用程序的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ActionView::Helpers::AssetTagHelper 和ActionView::Helpers::UrlHelper 模块包
含很多方法,它们可让你引用外部资源到当前“模板”中。当然,更通常使用的是link_to(),
它创建一个超链接给你的应用程序内的其它“动作”。
<%= link_to "Add Comment", :action => "add_comment" %>
传递给link_to()的第一个参数是用于显示这个链接的文本。下一个是指定链接目标的
哈希表。它们的格式与284 页中讨论的“控制器”的url_for()方法一样。第三个参数可以
用于设置被生成的链接的HTML 属性。这个属性支持一个额外的key 键,:confirm,它的值是
个短消息。如果出现的话,JavaScript 将被生成以显示此消息,并在链接之前接受用户的确
认。
<%= link_to "Delete", { :controller => "admin",
:action => "delete",
:id => @product
},
{ :class => "redlink",
:confirm => "Are you sure?"
}
%>
button_to()方法工作像link_to()一样,但生成个self-contained 窗体的按钮,而不
是一个平淡的链接。像我们在324 页16.9 节讨论的,这是链接带有副作用的“动作”的首选
方法。尽管这些按钮有它们自己的格式,它有很多重要的约束:它们不能内联,不能出现在
其它窗体内。
还有几个有条件连接方法,如果一些条件达到了,这些方法就生成链接,否则的话就返
回链接的文本内容。Link_to_unless_current()“帮助方法”对在sidebars 内创建菜单很有
用,在sidebar 内当前页的名字被显示为纯文本并且其它条目是超链接。
<ul>
<% %w{ create list edit save logout }.each do |action| -%>
<li>
<%= link_to_unless_current(action.capitalize, :action => action) %>
</li>
<% end -%>
</ul>
就像url_for( ), link_to( ) 和类似方法也支持绝对URL。
<%= link_to("Help", "http://my.site/help/index.html") %>
image_tag( ) “帮助方法”可以用于创建<img> 标记。
<%= image_tag("/images/dave.png", :class => "bevel", :size => "80x120")
%>
如果image 路径不包括一个”/”反斜线字符,则Rails 假设它放在/images 目录中。如
果没有文件扩展名,Rails 假设是.png。下面的代码与前面的例子是一样的。
<%= image_tag("dave", :class => "bevel", :size => "80x120") %>
你可以通过结合link_to()和image_to()把图像放到链接内。
<%= link_to(image_tag("delete.png", :size="50x22"),
{ :controller => "admin",
:action => "delete",
:id => @product },
{ :confirm => "Are you sure?" })
%>
mail_to()“帮助方法”创建一个mailto:超链接,在单击时,通常会加载客户端的e-mail
应用程序。它接受一个e-mail 地址,链接的名字,和一组HTML 选项。在些选项中,你也可
以使用:bcc,:cc,:body,和:subject 来初始化相应的email 字段。最后,魔术选
项:encode=>”javascript”使用客户端JavaScript 来暗中生成链接,这会让spiders 的搜
索引擎很难从你的站点中找到e-mails 地址。[但是也意味着如何你的浏览器关闭了
JavaScript 的话,你就不能看到e-mails 链接。]
<%= mail_to("support@pragprog.com", "Contact Support",
:subject => "Support question from #{@user.name}",
:encode => "javascript")
%>
AssetTagHelper 模块也包括这样的“帮助方法”,它可以轻易地让你的页连接样式表和
JavaScript 代码。我们在Depot 应用程序的“层”内,创建一个样式表连接,在head 中我
们使用stylesheet_link_tag()。
<%= stylesheet_link_tag "scaffold", "depot", :media => "all" %>
一个RSS 或Atom 链接是个header 字段,它指向我们应用程序的一个链接。当URL 被访
问时,应用程序应该返回相应的RSS 或Atom XML。
<html>
<head>
<%= auto_discovery_link_tag(:rss, :action => 'rss_feed') %>
</head>
. . .
最后,JavaScriptHelper“模型”定义许多“帮助方法”用于JavaScript 的工作。这些
create JavaScript 片断运行在浏览器中以生成特定的效果,并且可让页动态地与我们的应
用程序交流。这个主题在373 页的18 章自成一章。
缺省地,image 和stylesheet assets 放在运行的应用程序的/images 和/stylesheets
目录内。如果路径给出一个包含前反斜线的asset tag 方法,那么路径被认为是绝对的,并
且没有使用前缀。有时候它会移却它的静态内容到一个单独的box 内或是当前box 内的别的
位置。可通过设定配置变量asset_host 来做到。
ActionController::Base.asset_host = "http://media.my.url/assets"
内容概要:本文档是傲拓科技股份有限公司发布的NA200H可编程控制器(PLC)硬件手册,旨在详细介绍NA200H系列PLC的硬件特性、安装、拆卸与接线原则。NA200H系列PLC是一款小型一体化PLC,具有集成以太网接口,适用于恶劣运行环境,具备良好的扩展性能和低廉的价格。手册涵盖了NA200H PLC的硬件组成(包括CPU模块和各种扩展模块)、工作方式、编程软件介绍、快速应用指南以及详细的安装、拆卸与接线原则。此外,手册还提供了CPU模块和各类I/O扩展模块的技术参数、端子定义与接线说明,并介绍了多种通讯模块的功能和特性。最后,附录部分列出了订货参数和扩展模块的功率消耗清单。 适合人群:具备一定电气知识的操作人员和技术人员,特别是从事自动化控制系统设计、安装和维护的工程师。 使用场景及目标:①帮助用户了解NA200H PLC的硬件结构和工作原理;②指导用户正确安装、配置和维护NA200H PLC;③协助用户选择合适的扩展模块以满足特定的应用需求;④提供详细的接线和通讯配置指导,确保系统稳定运行。 阅读建议:本手册内容详尽,建议读者在使用产品前仔细阅读并理解相关内容,尤其是安装、拆卸和接线部分,以确保系统的安全和稳定运行。同时,建议结合实际应用场景,灵活运用手册中的信息,进行合理的系统设计和配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值