- 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/
我有一个 if 语句,如下所示 if (not(fullpath.lower().endswith(".pdf")) or not (fullpath.lower().endswith(tup
然而,在 PHP 中,可以: only appears if $foo is true. only appears if $foo is false. 在 Javascript 中,能否在一个脚
XML有很多好处。它既是机器可读的,也是人类可读的,它具有标准化的格式,并且用途广泛。 它也有一些缺点。它是冗长的,不是传输大量数据的非常有效的方法。 XML最有用的方面之一是模式语言。使用模式,您可
由于长期使用 SQL2000,我并没有真正深入了解公用表表达式。 我给出的答案here (#4025380)和 here (#4018793)违背了潮流,因为他们没有使用 CTE。 我很欣赏它们对于递
我有一个应用程序: void deleteObj(id){ MyObj obj = getObjById(id); if (obj == null) { throw n
我的代码如下。可能我以类似的方式多次使用它,即简单地说,我正在以这种方式管理 session 和事务: List users= null; try{ sess
在开发J2EE Web应用程序时,我通常会按以下方式组织我的包结构 com.jameselsey.. 控制器-控制器/操作转到此处 服务-事务服务类,由控制器调用 域-应用程序使用的我的域类/对象 D
这更多是出于好奇而不是任何重要问题,但我只是想知道 memmove 中的以下片段文档: Copying takes place as if an intermediate buffer were us
路径压缩涉及将根指定为路径上每个节点的新父节点——这可能会降低根的等级,并可能降低路径上所有节点的等级。有办法解决这个问题吗?有必要处理这个吗?或者,也许可以将等级视为树高的上限而不是确切的高度? 谢
我有两个类,A 和 B。A 是 B 的父类,我有一个函数接收指向 A 类型类的指针,检查它是否也是 B 类型,如果是将调用另一个函数,该函数接受一个指向类型 B 的类的指针。当函数调用另一个函数时,我
有没有办法让 valgrind 使用多个处理器? 我正在使用 valgrind 的 callgrind 进行一些瓶颈分析,并注意到我的应用程序中的资源使用行为与在 valgrind/callgrind
假设我们要使用 ReaderT [(a,b)]超过 Maybe monad,然后我们想在列表中进行查找。 现在,一个简单且不常见的方法是: 第一种可能性 find a = ReaderT (looku
我的代码似乎有问题。我需要说的是: if ( $('html').attr('lang').val() == 'fr-FR' ) { // do this } else { // do
根据this文章(2018 年 4 月)AKS 在可用性集中运行时能够跨故障域智能放置 Pod,但尚不考虑更新域。很快就会使用更新域将 Pod 放入 AKS 中吗? 最佳答案 当您设置集群时,它已经自
course | section | type comart2 : bsit201 : lec comart2 :
我正在开发自己的 SDK,而这又依赖于某些第 3 方 SDK。例如 - OkHttp。 我应该将 OkHttp 添加到我的 build.gradle 中,还是让我的 SDK 用户包含它?在这种情况下,
随着 Rust 越来越充实,我对它的兴趣开始激起。我喜欢它支持代数数据类型,尤其是那些匹配的事实,但是对其他功能习语有什么想法吗? 例如标准库中是否有标准过滤器/映射/归约函数的集合,更重要的是,您能
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 9 年前。 Improve
我一直在研究 PHP 中的对象。我见过的所有示例甚至在它们自己的对象上都使用了对象构造函数。 PHP 会强制您这样做吗?如果是,为什么? 例如: firstname = $firstname;
...比关联数组? 关联数组会占用更多内存吗? $arr = array(1, 1, 1); $arr[10] = 1; $arr[] = 1; // <- index is 11; does the
我是一名优秀的程序员,十分优秀!