- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在使用 jQuery 时,我试图通过单击按钮来动态地乘以表单元素(文件上传框)。代码如下:
$(document).ready(function () {
$('#new-image').click(function () {
var idx = $('.input.file').size();
var upload = $('.input.file:first-child').clone();
$(upload.find('label')).attr('for', 'Attachment'+idx+'File');
$(upload.find('input[type=file]')).attr('name', 'data[Attachment]['+idx+'][file]');
$(upload.find('input[type=file]')).attr('id', 'Attachment'+idx+'File');
upload.insertBefore('#new-image');
return false;
});
});
问题是,如果我尝试修改输入的名称,我最终会在发布请求中得到类似的内容 - 取自 Chrome 的(开发版本)控制台,在 Firefox (3.6) 上也会出现问题。
------WebKitFormBoundaryMXYcXg2mbP1HZsVJ
Content-Disposition: form-data; name="data[Attachment]​[3]​[file]"; filename="logo.png"
Content-Type: image/png
这不是因为字符串连接,我尝试使用硬编码值,但请求中的奇怪之处仍然存在。我在这里遗漏了一些东西还是这是 jQuery 中的错误?
(如果有人想知道,名称属性格式 - data[...
来自 CakePHP)
看来问题不是因为.attr()
,而是因为.clone()
。我相应地修改了问题。
我的印象是这有效:
upload.find('input[type=file]').name = 'data[Attachment]['+idx+'][file]';
// wrong -> find returns a jQuery object and setting name has no effect
因为我没有尝试添加多个文件,所以我只是尝试最后添加的字段:)。即使以正确的形式它也不起作用:
upload.find('input[type=file]').get(0).name = 'data[Attachment]['+idx+'][file]';
// I still get mumbo-jumbo in the post, between the ][ characters
我刚刚尝试不使用clone()
,这次它确实有效了:)。
$('#new-image').click(function () {
var idx = $('.input.file').size();
var upload = $('<div class="input file"><label for="Attachment'+idx+'File">File</label><input type="file" name="data[Attachment]['+idx+'][file]" id="Attachment'+idx+'File"></div>');
upload.insertBefore('#new-image');
return false;
});
有人知道为什么 clone()
会这样吗?
最佳答案
试试这个:
<div class="file">
<div>
<label for="Attachment0File">File: </label>
<input type="file" name="data[Attachment][file][]" id="Attachment0File" />
</div>
</div>
<button type="button" id="new-image">New</button>
$(document).ready(function () {
$('#new-image').click(function (e) {
e.preventDefault();
var idx = $('.file').length;
$('.file:first-child').clone(true, true)
.find('label').attr('for', 'Attachment'+idx+'File').end()
.find('input[type="file"]').attr('name', 'data[Attachment][file][]').attr('id', 'Attachment'+idx+'File').end()
.insertBefore('#new-image');
});
});
upload 不需要用 $() 包裹,因为它已经是一个 jQuery 对象了
关于jquery - jQuery 的 clone() 和 POST 请求的奇怪行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5398607/
什么是 vb6 或 java 中的对象克隆?我们在什么情况下使用克隆?克隆对象是什么意思?谁能用例子告诉我。 最佳答案 克隆实际上是将对象数据复制到新对象中。 此示例不克隆数据: Foo p = ne
ArrayList a=new ArrayList(); a.add(5); ArrayList b=(ArrayList)a.clone(); a.add(6); System.out.printl
这个问题在这里已经有了答案: Why does cloned() allow this function to compile (1 个回答) 关闭 3 个月前。 假设我们有一个可以克隆的某种类型的
我有这样的代码,我需要在其中将某些内容插入到两个单独的 HashMap 中。我只想要实现克隆的通用类型。 use std::collections::HashMap; use std::clone::
这段代码(also on play) use std::sync::Arc; struct Foo { x: isize, // Something complex in actual cod
我有按钮 Drag to insert h1 tag 当你拖动它时,我希望按钮留在原来的位置,助手是 Example在你放下它的地方,你会放下h1没有任何可拖动或 jQuery UI 样式的标记。 所
覆盖 clone 方法,而不实现 Cloneable 接口(interface)并且不调用 super.clone() 是一个好习惯。这样,就不会抛出 CloneNotSupportedExcepti
public abstract class Shape implements Cloneable { private String id; protected String type;
克隆远程仓库后,它不会通过 -a 选项显示任何远程分支。可能是什么问题呢?如何调试呢?在此片段中,未显示两个远程分支: $ git clone --depth 1 git://git.savannah
我看过这个答案for a git clone error ,建议不要克隆整个 repo,而是只克隆最新的提交,然后使用 unshallow 获取其余的提交。 考虑以下两个命令 1. git clone
当在网上搜索如何以多态方式深层复制对象的可能性时,我发现了 solution声称可以使用 clone() 方法解决许多问题,例如无法克隆 final 字段。该解决方案结合了在 clone() 实现中使
我正在尝试创建一个动态表单来向业务合作伙伴展示。 目标是能够在单击按钮时根据需要添加选择元素。但是,当它被点击时,它会复制模板两次,而不是一次。 这里只是我尝试过的代码的一些变体和 here is t
我知道实现 Object#clone() 的约定表明您应该调用 super.clone() 来获取复制的对象。 但我只是想知道如果我不这样做的话会有什么后果。让我们假设这个例子: class Some
我所说的示例:http://jsfiddle.net/bsnxp/1/ 如果你检查源 .show().clone() display 是 inline-block (它应该是什么)并且 .clone(
我正在编写代码来创建对象、克隆对象,然后比较两者。 所讨论的对象 Octagon 是对象 GeometricObject 的扩展 public class Octagon extends Geomet
我看到clone()在django代码中被广泛使用 queryset.query.clone() queryset.clone() 它的用途是什么?我应该模仿查询集或管理器方法中的行为吗? 最佳答案
我尝试导入 git project进入 eclipse 。手册告诉我在控制台中使用此命令: git clone http://git-wip-us.apache.org/repos/asf/mina-
我正在使用 jquery .clone(),它工作正常。但是我的问题是,当我克隆我的输入字段时,它也会克隆前一个字段的值。我不想克隆该值。我该如何克服这个问题? 这是我的代码 function add
在 this SO thread 中,结果表明,在制作项目副本方面,切片比任何方法都快。 使用: list1 = ['foo','bar'] copy1 = list1 * 1 list1.pop()
我有一个自动脚本可以解析服务器并克隆其中一个文件夹中的所有存储库。它所做的伪代码是: for each repo_name if a folder named like repo_name exi
我是一名优秀的程序员,十分优秀!