首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >cloneNode(true)不复制子元素

cloneNode(true)不复制子元素
EN

Stack Overflow用户
提问于 2014-03-19 21:26:28
回答 2查看 936关注 0票数 1

我有以下几点:

代码语言:javascript
复制
var divs = document.getElementsByClassName('projectListDiv');
var projectList = getProjects();
/* getProjects() generates a <select> element with multiple <option>s */
for(var i = 0; i < divs.length; i++){
    divs[i].innerHTML = "";
    var listCopy = projectList.cloneNode(true);
    divs[i].appendChild(listCopy);
}

getProjects()返回以下内容:

代码语言:javascript
复制
<select>
    <option value="test">test</option>
    <option value="Project Test">Stalker Test</option>
</select>

理论上,它应该用类<select>将一个projectListDiv元素附加到每个div。它确实附加了一个<select>元素,但是元素没有<options,尽管projectList显然有选项。我已经记录了所有的事情来安慰我,因为某种原因,当我cloneNode(true)的时候,我失去了projectList所有的孩子。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-03-19 21:30:25

我在http://jsfiddle.net/NSYRH/中做了一个示例,它使用自定义的getProjects()返回带有选项的select:

代码语言:javascript
复制
function getProjects() {
    var s = document.createElement('select');
    s.appendChild(new Option('a','avalue'));
    s.appendChild(new Option('b','bvalue'));
    s.appendChild(new Option('c','cvalue')); 
    return s;
}

我看不出这个代码有什么问题。

票数 1
EN

Stack Overflow用户

发布于 2014-03-19 21:57:52

异步模式,带有回调:

代码语言:javascript
复制
getProjects(function(projectList) {
   var divs = document.getElementsByClassName('projectListDiv');
   /* getProjects() generates a <select> element with multiple <option>s */
   for(var i = 0; i < divs.length; i++){
       divs[i].innerHTML = "";
       var listCopy = projectList.cloneNode(true);
       divs[i].appendChild(listCopy);
   }
})

function getProjects(successCallback) {
  var s = document.createElement('select');
  var xhr = new XMLHttpRequest(); 
  xhr.open('GET', '/something');
  xhr.onload = function() {
     /** use xhr.responseText here to add option to node s */
     /* then call the successCalback) */
     successCallback(s);
  }
  xhr.send();
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22518442

复制
相关文章

相似问题

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