如果标题有点不清楚,我深表歉意。基本上,问题在于:我有一个在名为 poll.php 的文件中生成的投票表单。因此,如果我转到/poll.php,它会向我显示该民意调查。我没有包括表单代码,因为它没有任何可能导致此问题的内容,因为它只有单选按钮、文本和提交按钮。我已将表单配置为使用 ajax,因此当我单击提交时,它会提交表单、查询数据库以获取最新数据并以图形形式将其显示给用户,而无需刷新页面。
这是运行以启用 ajax 的 javascript 代码:
$('body').on('submit', '#votePoll', function() {
$.get("/vote.php", $(this).serialize(), function(data) {
$("#content").html(data);
});
return false;
});
如代码所示,表单的 ID 设置为“votePoll”。正如我之前所说,如果我只是转到 poll.php,选择一个单选按钮并点击提交,它将执行上面的代码并正常工作。当插入第二个 ajax 阶段时,问题就来了。
显示网页的主要文件是index.php。
在 index.php 中,我运行以下 javascript 代码来获取在 poll.php 中创建的表单并显示它:
$(function() {
var pollContainer = document.getElementById('pollContainer');
$.ajax({
url:"/poll.php",
type:"POST",
success:function(msg){
pollContainer.innerHTML = msg;
}
});
})
如您所见,表单也是通过 ajax 获取的。 注意:在 index.php 中存在一个 DIV 容器,其中加载了表单,如上面的 javascript 代码中所述。它被命名为“pollContainer”。
接下来,当代码执行时,表单(可以在 poll.php 中看到)显示在 index.php 内的 div 容器中。
现在,目标是让它以与我直接进入 poll.php 时相同的方式工作,而是让 ajax 在容器内工作并按照在 中的方式更新 div 内容poll.php.
但是,问题是每当我单击“提交”时,页面不仅会刷新而不执行任何其他操作,而且它也无法计算投票并运行“vote.php”。
下面是生成表单的poll.php文件的一部分(显示在index.php的div容器中):
print "<div id='content'>
<form method='post' id='votePoll'>
<span><b>
{$qTitle}
</b></span><br>
<div class='radio'>
<label>
<input type='radio' name='option' id='optionsRadios1' value='1'>
{$q1}
</label>
</div>
<div class='radio'>
<label>
<input type='radio' name='option' id='optionsRadios1' value='2'>
{$q2}
</label>
</div>
<div class='radio'>
<label>
<input type='radio' name='option' id='optionsRadios1' value='3'>
{$q3}
</label>
</div>
<input type='submit' class='btn btn-default'>
</form>
</div>";
该文件中的其余代码和变量 q1 等不包含在此代码中,但它们的工作是从数据库中检索信息并显示它。
让我感到困惑的是,为什么代码在直接转到 poll.php 和投票时可以完美运行,但在以 index.php 中显示的形式进行投票时却不起作用。 php.
如果我犯了错误或忘记添加某些内容,请告诉我。
更新:上面发布的两个 JS 代码块都在单独的文件中,这些文件在 index.php 页面中被引用。
最佳答案
我猜问题是 $(function() {...}); 调用,它本质上是 $(document).ready(function() { ...});。当您使用 Ajax 调用更改 DOM 时,不会触发文档就绪事件,因此您的事件处理程序不会绑定(bind)。
使用 Event Delegation ,您可以在 index.php 中尝试 $('body').on('submit', '#votePoll', function() {...}); 而不是在民意测验.php。这应该将您的事件处理程序绑定(bind)到正文中所有当前和 future 的#votePoll 元素。
关于php - Ajax 投票民意调查直接工作,但不是通过第二个 ajax 调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19307094/
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
如何在ruby中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL
rails中是否有任何规定允许站点的所有AJAXPOST请求在没有authenticity_token的情况下通过?我有一个调用Controller方法的JqueryPOSTajax调用,但我没有在其中放置任何真实性代码,但调用成功。我的ApplicationController确实有'request_forgery_protection'并且我已经改变了config.action_controller.consider_all_requests_local在我的environments/development.rb中为false我还搜索了我的代码以确保我没有重载ajaxSend来发送
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我需要一些关于TDD概念的帮助。假设我有以下代码defexecute(command)casecommandwhen"c"create_new_characterwhen"i"display_inventoryendenddefcreate_new_character#dostufftocreatenewcharacterenddefdisplay_inventory#dostufftodisplayinventoryend现在我不确定要为什么编写单元测试。如果我为execute方法编写单元测试,那不是几乎涵盖了我对create_new_character和display_invent