- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我最近读到在 JavaScript 中嵌入 ruby 不是一个好主意。然而,在 David Heinemeier Hansson 的 Agile Web Development with Rails 等书籍中,这正是它所做的。如果将 ruby 嵌入 JS 不是一个好主意,那么这种情况下的最佳做法是什么?给出像这样简单的东西:(jQuery + ruby)
posts_controller
def create
@post = Post.new(params[:post])
respond_to do |format|
if @post.save
format.html { redirect_to(@post, :notice => 'Post was successfully created.') }
format.js #will use this response to process ajax
else
format.html { render :action => "new" }
end
end
end
create.js.erb
$tr = $('<tr>');
$td1 = $('<td>').text('<%= @post.title %>');
$td2 = $('<td>').text('<%= @post.content %>');
$tr.append($td1, $td2);
$('table tbody').append($tr);
应该如何重构以遵循不将 ruby 嵌入 JS 的“最佳实践”?(如果是这样的话)
我真的需要在这方面有所启发,也许要弄清楚概念,因为我读过 Rails 3.1 将通过 Assets 将 JS 与 Ruby 完全分开?(这是正确的吗?)
谢谢!
最佳答案
RJS 模板本质上是很长一段时间内完成事情的方式,这就是为什么您仍然在教程中看到这种技术如此流行的原因。话虽这么说,正如您所注意到的,他们正在走出去,而且有充分的理由。
我确信 RJS 模板非常糟糕的原因有很多,但一个重要原因是它们将您的 View JS 与您的 View HTML 耦合得有多紧密.许多问题由此产生,其中一些是:
缺乏灵 active 。
以您的代码为例。如果您希望能够从不同的 Angular 创建帖子怎么办?并有不同的效果?也许没有 <table>
在所有页面上,您只想弹出一条“成功”消息?等等
如果您只想要帖子的数据表示,但您的 javascript 模板是为操作 HTML 而编写的怎么办?
你如何处理所有这一切create.js.erb
,这很可能与帖子 new.html.erb
紧密耦合模板?
复杂性。
RJS 模板在某种程度上是在真空中运行的。在服务器端生成,它们的执行不绑定(bind)到 DOM 事件。这使得执行诸如更新 <form>
之类的事情变得棘手。在创建对象后的页面上,因为您没有引用框架来选择适当的 <form>
在 JS 模板中(例如 <form id="new_post_123">
)。有一些解决方法,但它们比需要的更复杂。
通过绑定(bind)到表单客户端并处理结果,这个问题就被消除了。您无需在回复后找到合适的表格进行更新。
对于 RJS,您没有这样的绑定(bind),并且您被迫使用 HTML 的已知结构来检索和操作适当的元素。不必要的复杂性的一个例子。
I really need to be enlightened on this, and maybe get the concepts right because I have read that rails 3.1 will separate JS from Ruby completely through assets ?(Is this correct?)
这基本上是正确的。 Assets 管道虽然很酷,但并没有提供任何全新的东西。 Sprockets 和 Sass 等 Assets 框架及其支持的工作流已经存在了一段时间。 Rails 3.1 asset pipeline 只是将它们带入了标准实践。正如 DHH 在他最近的 RailsConf keynote 中谈到的,这更像是一个视角问题。 .通过对这些 Assets (尤其是 js 文件)进行更好的组织,它使它们感觉更像是一等公民,可以这么说,值得像您的后端代码一样受到关注。与 public/javascripts
的“垃圾抽屉”感觉相反.
你可以这样做(虽然未经测试并且有点简化,例如在 Rails 3 中你可以使用响应器而不是 respond_to block :
# as you have, but returning the object as data which can be handled client-side,
# rather than RJS generated by the server
def create
@post = Post.new(params[:post])
respond_to do |format|
if @post.save
format.js { render :json => @post }
else
# ...
end
end
end
// Then in your client side JS, a handler for your remote form.
$(function(){
$('#your-create-form').bind('ajax:success', function(data, status, xhr) {
// simply repeating what you had in the template, replacing the erb with
// attributes from the returned json
$tr = $('<tr>');
$td1 = $('<td>').text(data.title);
$td2 = $('<td>').text(data.content);
$tr.append($td1, $td2);
$('table tbody').append($tr);
});
}
关于javascript - 拥有混合 Javascript 和 ruby 的文件是否正确? IE。 (.js.erb)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7221923/
拥有/想要列表匹配算法 我正在一个高流量网站上实现一个元素交易系统。我有大量用户,每个用户都为许多特定项目维护一个 HAVE 列表和一个 WANT 列表。我正在寻找一种算法,使我能够根据您的 HAVE
我可以知道拥有 .hgtags 的目的是什么吗?我可以删除它吗?因为它不在 .hg文件夹,似乎“污染”了我的实际源代码目录。 https://bz.mercurial-scm.org/show_bug
在哪些用例中使用 [[nodiscard]] 有益类型? 关于类型,[[nodiscard]]如果任何返回该类型实例的函数的返回值被省略,则发出警告; (引自 p0068r0): If [[nodis
我知道当一个对象只有一个所有者时使用std::unique_ptr,当一个对象有多个所有者时使用std::shared_ptr。成为对象的唯一所有者意味着什么? 成为唯一所有者是否意味着其他人都无法看
我无法真正理解拥有 vendor 文件夹的目的。根据我了解到的情况, vendor 文件夹似乎只有在您尝试使您的存储库与早于 1.11 的 golang 版本兼容时才有用。 .我们正在运行 golan
我正在尝试学习如何在 Raspberry PI 上编码。我来自使用 Windows 和 VS Code 进行编码。现在我使用 Linux Mint 19.1 和 ssh 访问 Raspbian 4.1
我有一个带有“BlockType”枚举的图形程序。根据州的不同,这可能是以下几种情况之一:木头、石头、草地等。 最初,必须针对每种可能性执行各种纹理操作,但由于进行了一些重构,枚举仅用作整数,swit
我正在创建一个网络应用程序,让用户可以搜索餐馆和咖啡馆。由于我目前除了类型之外没有其他数据来区分这两者,所以我有两种存储餐馆列表的选择。 对餐厅和咖啡馆使用同一张表,并使用枚举(文本)列说明条目是餐厅
我有一个 5 人的小团队,我需要帮助寻找有关如何拥有一个集中式 MySQL 数据库的资源或建议。我们都以虚拟方式工作,并将所有文件托管在一个 github 上以集中所有内容。因此,在不同的计算机上拥有
SELECT dnum , SUM(IF(salary>20000, 1, 0)) AS Employee FROM project INNER JOIN works_on ON pno=pnumbe
我想在 javascript 中有一个数组,其中每个项目包含 2 个属性而不是 1 个,这怎么可能? 默认情况下,以下内容仅向项目添加一个属性: var headerCellWidths = new
我确定我对这个问题的措辞很糟糕,但这是我的问题: 我正在创建一长串地毯,每 block 地毯都有图片、标题、尺寸、原价和清仓价。我将每 block 地毯都放在自己的类别中,并对其余的地毯重复这样的操作
我正在编写一个延迟渲染器,并试图打包我的 gbuffer。 将漫反射和高光存储在一起会更好吗: vec4 difSpec = (diffuse.xyz, specular) // FORMAT_RGB
下面的程序给我一个链接时错误: #include struct Test { static constexpr char text[] = "Text"; }; int main() { s
想知道 - 如果了解Linux 的生活方式或 Linux 架构,是否会为在嵌入式设备上编程提供更好的思路,尤其是当它们具有某种操作系统时。 只是想确定我没有错过任何重要的事情:) 注意: 我来自 wi
如果要测试 iPhone 应用程序,拥有一个开发代码签名条款来运行任何带有 com.mydomain.* 的应用程序是不是一个坏主意? 为什么? 编辑: 请参阅上面的斜体编辑。 最佳答案 我对此表示怀
我正在开发我自己的 Swift 框架,以便在我的两个应用程序之间私下使用。我正在使用 Carthage 来管理该依赖项和其他依赖项。 我终于完成了框架的开发并将其连接到我的一个应用程序,毫不奇怪,该应
如果我有一个 C 类型的原始指针,是否可以从拥有指针数据的相同类型创建一个 std::vector 而无需任何数据复制(仅 move )?促使我问这个问题的是 std::vector 的 data()
有 2 个部分的好处是什么 - .data 和 .bss 用于流程范围变量。为什么不只拥有一个呢?我知道每个部分的用途。我正在使用 gcc。 最佳答案 .bss 消耗“内存”但不消耗可执行文件中的空间
我注意到,我们可以使用 StatefulWidget 构建 UI 的任何部分,而无需担心状态。 我想问的很简单,当我们可以将任何 UI 类构建为 StatefulWidget 时,首先拥有 State
我是一名优秀的程序员,十分优秀!