我在div中有一些输入。看起来是这样的:
<div name="emailInput">
<input type="text" name="email_1" /></div>
<div name="phoneInput">
<input type="text" name="phone_number_1" /></div>
<div name="emailInput">
<input type="text" name="email_2" /></div>
<div name="phoneInput">
<input type="text" name="phone_number_2" /></div>
<div name="emailInput">
<input type="text" name="email_3" /></div>
<div name="phoneInput">
<input type="text" name="phone_number_3" /></div>但在某些情况下,我需要更改输入的顺序。具体地说,我想交换电子邮件和电话位置。结果必须为:
<div name="emailInput">
<input type="text" name="phone_number_1" /></div>
<div name="phoneInput">
<input type="text" name="email_1" /></div>
<div name="emailInput">
<input type="text" name="phone_number_2" /></div>
<div name="phoneInput">
<input type="text" name="email_2" /></div>
<div name="emailInput">
<input type="text" name="phone_number_3" /></div>
<div name="phoneInput">
<input type="text" name="email_3" /></div>为了实现我的目标,我编写了jquery代码:
$('div[name^= emailInput]').insertBefore('div[name^= phoneInput]');这段代码在每个emailInputs div之前交换了整个phoneInputs div。如何逐个交换div?(输入的计数未知)
另外,
$('input[name^= email]').insertBefore('input[name^= phone_number]');不起作用。
发布于 2012-09-12 00:58:32
试试这个:
$('input[name^="phone_number"]').each(function(){
var $this = $(this);
var $prev = $this.parent().prev()
$prev.find('input').insertAfter($this);
$this.appendTo($prev)
})http://jsfiddle.net/PnT4Q/1/
您还可以更改div标记的位置。
$('div[name="phoneInput"]').each(function(){
var $this = $(this);
$this.insertBefore($this.prev())
})发布于 2012-09-12 00:51:54
我还没有试过这个..但我认为应该是这样的:
$('div[name=^ emailInput]').each(obj, function(i, val) {
obj.insertBefore('div[name^= phoneInput]');
});发布于 2012-09-12 00:53:46
您需要单独操作它们,而不是整个选择器组。
$('div[name^="emailInput"]').each(function(){
var previousPhoneInput = $(this).prev("div[name^='phoneInput']");
$(this).remove().insertBefore(previousPhoneInput);
});https://stackoverflow.com/questions/12374321
复制相似问题