添加和删除文本框元素
我设法在网上找到允许我删除和添加文本框的代码。但是,我正在尝试修改代码以适应我在同一页面上的单独迭代中添加和删除文本框的情况,这些代码不允许我这样做。这是我用于添加和删除的代码:
$('#btnAdd').click(function() {
var num = $('.clonedInput').length; // how many "duplicatable" input fields we currently have
var newNum = new Number(num + 1); // the numeric ID of the new input field being added
// create the new element via clone(), and manipulate it's ID using newNum value
var newElem = $('#input' + num).clone().attr('id', 'input' + newNum);
// manipulate the name/id values of the input inside the new element
newElem.children(':first').attr('id', 'name' + newNum).attr('name', 'name' + newNum);
//prepend table code
$('#input' + num).append('<tr><td colspan="2"><label>');
// insert the new element after the last "duplicatable" input field
$('#input' + num).after(newElem);
//prepend table code
$('#input' + newNum).append('</label></td></tr>');
// enable the "remove" button
$('#btnDel').attr('disabled','');
// business rule: you can only add XXX times
if (newNum == 5)
$('#btnAdd').attr('disabled','disabled');
return false
});
$('#btnDel').click(function() {
var num = $('.clonedInput').length; // how many "duplicatable" input fields we currently have
$('#input' + num).remove(); // remove the last element
// enable the "add" button
$('#btnAdd').attr('disabled','');
// if only one element remains, disable the "remove" button
if (num-1 == 1)
$('#btnDel').attr('disabled','disabled');
return false
});
$('#btnDel').attr('disabled','disabled');
这是一个 链接到我的意思: '+' & '-' 符号是代码的用途,但它们不能在单独的场合使用...我该怎么做才能使它们在同一个 html 页面上可用,无论我打算增加或减少迭代次数?
I manage to find code online that allows me to remove and add textbox. However, i am trying to modify the codes to suit my situation of adding and removing textbox in separate iterations all on the same page and these codes does not allow me to do that..Here's my code for adding and removing:
$('#btnAdd').click(function() {
var num = $('.clonedInput').length; // how many "duplicatable" input fields we currently have
var newNum = new Number(num + 1); // the numeric ID of the new input field being added
// create the new element via clone(), and manipulate it's ID using newNum value
var newElem = $('#input' + num).clone().attr('id', 'input' + newNum);
// manipulate the name/id values of the input inside the new element
newElem.children(':first').attr('id', 'name' + newNum).attr('name', 'name' + newNum);
//prepend table code
$('#input' + num).append('<tr><td colspan="2"><label>');
// insert the new element after the last "duplicatable" input field
$('#input' + num).after(newElem);
//prepend table code
$('#input' + newNum).append('</label></td></tr>');
// enable the "remove" button
$('#btnDel').attr('disabled','');
// business rule: you can only add XXX times
if (newNum == 5)
$('#btnAdd').attr('disabled','disabled');
return false
});
$('#btnDel').click(function() {
var num = $('.clonedInput').length; // how many "duplicatable" input fields we currently have
$('#input' + num).remove(); // remove the last element
// enable the "add" button
$('#btnAdd').attr('disabled','');
// if only one element remains, disable the "remove" button
if (num-1 == 1)
$('#btnDel').attr('disabled','disabled');
return false
});
$('#btnDel').attr('disabled','disabled');
Here's a link to the idea of what i mean:
The '+' & '-' signs are what the codes are used for but they cannot be used on separate occasions...what can i do to make them usable on the same html page regardless of the number of iterations i intend to increase or decrease?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
首先,我认为你应该尝试编写一个插件并从这里开始
然后您说 + 和 - 按钮不能在单独的场合使用。我假设整个元素已克隆到您的代码中,并且我看不到 + 和 - 元素是如何创建的,但如果它们有 ID,它们可能不再是唯一的,因此它们可能不会执行您期望它们执行的操作。因此,请确保 ID 是唯一的,甚至更好,不要在这种情况下使用 ID,而是给它们一个不必是唯一的类名,并且在删除时删除如下:
希望这可以帮助您更进一步。如果没有,请在此处发送更多详细信息。
First of all I think you should try to write a plugin and start here for example.
Then you do not need to number the elements you add. If you remove the last one you can simply use:
Then you say the + and - buttons can't be used on separate occassions. I assume the whole element is cloned in your code and I cannot see how the + and - elements are created but if they have an ID they might not be unique anymore and therefore they might not do what you expect them to do. So make sure the ID's are unique or even better, do not use ID's in the case but give them a classname which does not have to be unique and when removing remove like:
Hope this helps you a few steps further. If not, please send more details here.