RJS Templates for Rails的thought_log程序

本文介绍了一个基于Rails框架的应用——思想日志(Thought Log),该应用允许用户远程记录和显示想法。通过使用form_remote_tag和RJS技术实现AJAX功能,无需页面刷新即可更新想法列表。

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

thought_log是《RJS Templates for Rails》的Getting Started程序
app/controllers/thoughts_controller.rb:
[code]
class ThoughtsController < ApplicationController
def log
@thought = params[:thought]
end
end
[/code]
app/views/thoughts/index.rhtml:
[code]
<!DOCTYPE html PUBLIC "-//W3C/DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
<title>Thought Log</title>
<%= javascript_include_tag :defaults %>
</head>
<body>
<h1>My thoughts</h1>

<%= form_remote_tag :url => {:action => 'log'}, :html => {:id => 'thought-form'} %>
<%= text_field_tag 'thought', nil, :size => 40 %>
<%= submit_tag 'Log thought' %>
<%= end_form_tag %>

<div id="thoughts"></div>
</body>
</html>
[/code]
app/views/thoughts/_thought.rhtml:
[code]
<p>
<span style="font-size: 0.8em;">[<%= Time.now.to_s(:db) %>]</span>
<%= h thought %>
</p>
[/code]
app/views/thoughts/log.rjs:
[code]
page.insert_html :bottom, 'thoughts', :partial => 'thought'
page.visual_effect :highlight, 'thoughts'
page.form.reset 'thought-form'
[/code]
需要注意的两点:
1,不要在form_remote_tag中使用:update,否则会生成Ajax.Updater这个Prototype对象而不会生成Ajax.Request对象,前者使用response内容更新一个单独的DOM元素,而后者使用RJS模板返回JavaScript到浏览器并执行。
2,当xx.rhtml和xx.rxml模板与xx.rjs模板在一个目录共存时,xx.rhtml和xx.rxml模板会比xx.rjs模板先被找到并渲染,这样RJS模板就失效了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值