在Rails Layout中使用JQuery的解决办法

本文探讨了在Rails应用中如何有效地将JQuery初始化代码与布局文件结合使用。提出两种解决方案:一是直接利用Rails的content_for方法;二是进一步封装content_for以提供更灵活的使用方式。

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

原文地址:[url]http://blog.tech4k.com/?p=256[/url]
Rails的Layout非常的好用,可以把Header,Footer,SideBar在一个公共的页面,统一风格而且非常的易于维护.
JQuery是我比较喜欢的js framework,强大的selector绝对符合我的口味,不二的选择.<br/>
问题就来了,Layout中通常包含了<header>的内容,而JQuery需要在header通过如下的code实现初始化.
[code]
<script type="text/javascript">
$(document).ready(function(){
......
}
</script>
[/code]
而这部分代码肯定是根据具体的功能页面不同而有所不同的,无法直接写在Layout页面中,那该怎么办?

[b]Solution 1[/b]
我自己找到并使用的解决办法:神奇的方法[b]content_for[/b]
[url]http://railscasts.com/episodes/8-layouts-and-content-for[/url].
在Layout文件中加入如下的code.
[code]
<head>
<title>My Tasks</title>
<%= yield :jquery %>
</head>
[/code]
在具体的功能页面中通过如下形式定义JQuery初始化脚本.
[code]
<% content_for :jquery do %>
<script type="text/javascript">
$(document).ready(function(){
......
}
</script>
<% end %>
[/code]
OK了.这样就可以了.这个解决办法的问题是你必须在每个功能页面实现一边初始化脚本.另外如果header,sidebar需要用到jquery的话还需要额外处理.不过因为这些在我的应用中暂时都不需要,所以这个解决办法对我而言还是可以的.

[b]Solution 2[/b]
这是Javaeye上[url=http://jonny131.iteye.com/]小小龙猫[/url]提供的解决办法.
[url]http://jonny131.iteye.com/admin/blogs/179842[/url]
最基础的方法还是使用content_for这个方法.不过封装的要更加好,使用起来更加灵活.有兴趣的同学可以参考一下.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值