0

我目前正在尝试在单击按钮时加载部分内容。所以我要做的是添加一个远程 => true,然后在控制器操作中添加一个 format.js,该操作将转到我执行此操作的 .js.erb 文件:

$('#videospan').html('<%= escape_javascript(render :partial => 'newpartial') %>');

现在,videospan 已经有了不同的部分,现在我要添加这个部分。当涉及到它的 html 部分时,这很好用。现在 newpartial 里面有一些 javascript,不幸的是没有检测到。是因为 html 是在 javascript 之前加载的吗?如何使它对 HTML 可见?我必须在原始 html 文件中定义它吗?

谢谢,


一种javascript方法:

function saveAll()
{
     for(key in storedData){
        storedData[key].push.apply(storedData[key],[$('#'+key).position().top,$('#'+key).position().left]);
    }


    $.getJSON('<%= save_answers2_course_lecture_path(@course, @lecture) %>',{"stored":storedData}, function(resp){
        redirect()
    });
}

所以现在我试图通过将javascript也添加到js.erb来传递它,所以现在我在js.erb中有这个:

$('#videospan').html('<%= escape_javascript(render :partial => 'newpartial') %>');
pop = Popcorn.youtube( "#youtube", lec ,{ width: 400, controls: 0});                           
pop.play();

所以我想渲染其中有一个#youtube div的部分,然后我想使用爆米花向它添加一个视频。不幸的是,当我添加这 3 行时,甚至渲染都不起作用..


使用 firebug,当我检查返回的响应时,它看起来像这样:

$('#videospan').html(".........");
pop = Popcorn.youtube( "#youtube", http://www.youtube.com/... ,{ width: 400, controls: 0}); 
pop.controls( false );                          
pop.play();

所以一切都正确发送了,但是怎么没有显示呢?

4

2 回答 2

1

万一有人面临某人的问题..这是由于我遇到的错误。据此:http ://www.alfajango.com/blog/rails-js-erb-remote-response-not-executing/

当 .js.erb 文件中存在错误时,代码会静默失败。要检查错误,只需从 firebug 复制响应,将其发布到命令行并运行它。

于 2012-11-29T22:54:13.113 回答
1

您最好将尽可能多的 Javascript 移动到脚本文件中。一种方法是将功能分解为代码与配置数据:将代码放入 .js 文件中,将数据放入 DOM 或变量中:

// Option1 -- Using DOM
// my_function.js
function saveAll() {
  // code code code
  var url = $('#some_dom_element').attr('data-some-attribute-name');

  $.getJSON(url, 'blah blah');
}

# my_template.js.erb
<div id="some_dom_element" data-some-attribute-name="<%= save_answers2_course_lecture_path( @course, @lecture) %>">
</div>

// Option 2 -- Using a variable
// my_function.js
function saveAll() {
  // code code code
  $.getJSON(url, 'blah blah');
}

# my_template.js.erb
var url = '<%= raw(save_answers2_course_lecture_path( @course, @lecture) %>';
于 2012-11-29T18:16:28.023 回答