rails应用ajax之二:使用rails自身支持
来源:互联网 发布:注册登录源码 编辑:程序博客网 时间:2024/05/21 19:48
考虑另一种情况:
1. 页面上半部分显示当前的所有用户,页面下半部分是输入新用户的界面;
2. 每当输入新用户时,页面上半部分会动态更新新加用户的内容;
我们还是用ajax实现,不过这次用rails内部对ajax的支持,其中在服务器端返回一个js脚本,然后在客户端执行。
新建user数据结构 rails g scaffold User name:string age:integer
接着应用数据库视图 rake db:migrate
修改index.html.erb的内容:
<h1>Listing Users</h1><ul id="users"><%= render @users%></ul><br /><%= form_for(@user,remote:true) do |f|%><%= f.label :name %><br \><%= f.text_field :name %><%= f.label :age %><br \><%= f.text_field :age%><%= f.submit %><% end %>
同时新建一个局部模板_users.html.erb:
<li><%= user.name%></li><li><%= user.age%></li>
接下来增加服务器端对js的支持,很简单:
def index @users = User.all @user = User.new #puts "******* #{render @user} **********" end # POST /users # POST /users.json def create @user = User.new(user_params) respond_to do |format| if @user.save format.html { redirect_to @user, notice: 'User was successfully created.' } format.js {} #增加这一句 format.json { render :show, status: :created, location: @user } else format.html { render :new } format.json { render json: @user.errors, status: :unprocessable_entity } end end end
别忘了还要写服务器端的js脚本哦。在view下的users目录中新建一个create.js.erb文件:
$("<%= escape_javascript(render @user)%>").appendTo("#users");<!--$("#users").append("<p>love</p>");-->
基本完成鸟。整个流程大体如下:
首先用户访问users/index页面,当输入name和age点击提交后会进入create Action,其中的format.js一句提供了ajax支持,它会在浏览器端执行create.js.erb的内容:把新建用户信息异步动态插入页面上半部分。
0 0
- rails应用ajax之二:使用rails自身支持
- rails ajax jquery 应用
- rails中使用ajax
- rails之webservice应用
- NetBeans Ruby on Rails中使用Ajax(二)
- rails应用ajax之一:使用纯js方法
- Ruby on Rails 使用 Ajax
- Rails Ajax
- RAILS AJAX
- rails ajax
- 使用monit监控rails应用
- Ruby on Rails 中应用Ajax
- Ruby on Rails 中应用Ajax
- Rails 3入门之二 2- 2 Rails组件
- rails应用ajax之三:进一步完善ajax动画特效果
- Rails
- Rails
- Rails
- (转载)Cloudera manager free 的使用
- Android 判断当前设备是手机还是平板
- Flashcache基本使用及注意事项
- ZStack-CC2530-2.5.1a协议栈数据传输
- 第八阶段:Broadcast学习
- rails应用ajax之二:使用rails自身支持
- cocos2d-x-3.3-015-程序入口main
- hibernate 懒加载
- java--->多线程
- 在web.xml中配置异常处理页面
- 20150105-20150110工作周志
- google商店打不开,通过下载插件安装红杏插件
- 使用Android Studio构建Android项目常见问题收集
- @synthesize和@dynamic区别