rails,ruby代码嵌入模板文件标记符<% %>

在Rails 中,输出的文件通常是HTML 格式,但也可以是别的任何东西。普通的内容会直进直出,没有任何变化。但<%= 和%> 符号之间的内容则会被看作Ruby 代码执行,执行的结果将被转换为字符串,并替换到文件中 <%=...%> 序列所在的位置。譬如说,我们在 hello.html.erb 中加入下列内容:

Download erb/ex1.html.erb
<ul>
<li>Addition: <%= 1+2 %> </li>
<li>Concatenation: <%= "cow" + "boy" %> </li>
<li>Time in one hour: <%= 1.hour.from_now %> </li>
</ul>
刷新浏览器,模板就会生成下列HTML :
<ul>
<li>Addition: 3 </li>
<li>Concatenation: cowboy </li>
<li>Time in one hour: Fri May 23 14:30:32 -0400 2008</li>
</ul>
在浏览器窗口中,你会看到下列内容:
Addition: 3
 Concatenation: cowboy
 Time in one hour: Fri May 23 14:30:32 -0400 2008
另外,在.html.erb 文件中, <% 与%> 符号( 前者没有等号) 之间的内容会被看作Ruby 代码执行&

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要为 Ruby on Rails 程序加入拖曳排序功能,你可以使用 jQuery UI 的 Sortable 插件和 Rails 的 AJAX 功能来实现。 首先,在你的 Rails 应用程序中安装 jQuery UI: ```ruby # Gemfile gem 'jquery-ui-rails' ``` 然后,在应用程序的 JavaScript 文件中添加以下代码: ```javascript // app/assets/javascripts/application.js //= require jquery-ui/widgets/sortable $(document).ready(function() { $('ul.sortable').sortable({ axis: 'y', update: function(event, ui) { $.ajax({ url: '/items/sort', type: 'PATCH', data: $(this).sortable('serialize'), success: function() { console.log('Items sorted'); } }); } }); }); ``` 上面的代码将为具有 `sortable` 类的 `ul` 标签添加拖曳排序功能。当用户完成排序并释放鼠标时,它将向 `/items/sort` 发送一个 PATCH 请求,其中包含排序后的项目信息。 接下来,在控制器中添加 `sort` 动作: ```ruby # app/controllers/items_controller.rb class ItemsController < ApplicationController def sort params[:item].each_with_index do |id, index| Item.where(id: id).update_all(position: index + 1) end head :ok end end ``` 上面的代码将根据传递的项目 ID 更新其位置。最后,你需要在视图中为每个项目添加位置属性: ```html <!-- app/views/items/index.html.erb --> <ul class="sortable"> <% @items.each do |item| %> <li data-id="<%= item.id %>"> <%= item.name %> <span class="position"><%= item.position %></span> </li> <% end %> </ul> ``` 这就是为 Ruby on Rails 程序添加拖曳排序功能的基本步骤。你可以根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值