首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >替换div (交换div)

替换div (交换div)
EN

Stack Overflow用户
提问于 2012-09-12 00:45:57
回答 3查看 128关注 0票数 1

我在div中有一些输入。看起来是这样的:

代码语言:javascript
复制
<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>

但在某些情况下,我需要更改输入的顺序。具体地说,我想交换电子邮件和电话位置。结果必须为:

代码语言:javascript
复制
<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代码:

代码语言:javascript
复制
$('div[name^= emailInput]').insertBefore('div[name^= phoneInput]');

这段代码在每个emailInputs div之前交换了整个phoneInputs div。如何逐个交换div?(输入的计数未知)

另外,

代码语言:javascript
复制
  $('input[name^= email]').insertBefore('input[name^= phone_number]');

不起作用。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-09-12 00:58:32

试试这个:

代码语言:javascript
复制
$('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标记的位置。

代码语言:javascript
复制
$('div[name="phoneInput"]').each(function(){
  var $this = $(this);
  $this.insertBefore($this.prev())   
})
票数 0
EN

Stack Overflow用户

发布于 2012-09-12 00:51:54

我还没有试过这个..但我认为应该是这样的:

代码语言:javascript
复制
$('div[name=^ emailInput]').each(obj, function(i, val) {
      obj.insertBefore('div[name^= phoneInput]');

    });
票数 0
EN

Stack Overflow用户

发布于 2012-09-12 00:53:46

您需要单独操作它们,而不是整个选择器组。

代码语言:javascript
复制
 $('div[name^="emailInput"]').each(function(){
      var previousPhoneInput = $(this).prev("div[name^='phoneInput']");
      $(this).remove().insertBefore(previousPhoneInput);
    });
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12374321

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档