Javascript 如何在随机化有序列表中随机化多个无序列表?

Javascript 如何在随机化有序列表中随机化多个无序列表?,javascript,html,list,random,Javascript,Html,List,Random,我正在尝试用包含随机答案(随机排列无序列表)的随机问题(随机排列有序列表)进行测试。我可以让有序列表随机化,但我只能让一个无序列表随机化。该代码只会随机化它找到的第一个无序列表。我想随机化所有无序列表。感谢您的帮助 <ol> <li>What are the three main areas of the Standard User Interface? <ul type="none"> <li><input type="radi

我正在尝试用包含随机答案(随机排列无序列表)的随机问题(随机排列有序列表)进行测试。我可以让有序列表随机化,但我只能让一个无序列表随机化。该代码只会随机化它找到的第一个无序列表。我想随机化所有无序列表。感谢您的帮助

<ol>
<li>What are the three main areas of the Standard User Interface?
  <ul type="none">
    <li><input type="radio" name="q1" value="0" />A. Header, Banner, Frame, Application Window</li>
    <li><input type="radio" name="q1" value="0" />B. Content Frame, Homepage, Form </li>
    <li><input type="radio" name="q1" value="1" />C. Application Navigator, Banner Frame, Content Frame </li>
    <li><input type="radio" name="q1" value="0" />D. None of the above</li>
  </ul>
</li>

<li>In the User interface, what is the gray toolbar called which allows you to add bookmarks?<br/>

  <ul type="none">
    <li><input type="radio" name="g2" value="0" />A. Gauge</li><br />
    <li><input type="radio" name="g2" value="1" />B. Edge</li><br />
    <li><input type="radio" name="g2" value="0" />C. Remedy</li><br />
    <li><input type="radio" name="g2" value="0" />D. Banner</li><br />
  </ul><br/>
</li>

<li>What can be captured in an update set?<br/>

  <ul type="none">
    <li><input type="radio" name="g3" value="0" />A. Modified CI Rules</li><br />
    <li><input type="radio" name="g3" value="1" />B. Business Rules</li><br />
    <li><input type="radio" name="g3" value="0" />C. Scheduled Jobs</li><br />
    <li><input type="radio" name="g3" value="0" />D. None of the above</li><br />
  </ul>
</li>

<li>What should you always do before you commit an update set?<br/>

  <ul type="none">
    <li><input type="radio" name="g4" value="1" />A. Preview</li><br />
    <li><input type="radio" name="g4" value="0" />B. Merge</li><br />
    <li><input type="radio" name="g4" value="0" />C. Ignore</li><br />
    <li><input type="radio" name="g4" value="0" />D. All of the above</li><br />
  </ul>
</li>

<li>Which of the following is a Business Rule best pratice?<br/>

  <ul type="none">
    <li><input type="radio" name="g5" value="1" />A. Make business rules small and specific</li><br />
    <li><input type="radio" name="g5" value="0" />B. Use of conditions is not necessary</li><br />
    <li><input type="radio" name="g5" value="0" />C. Global business rules should be used</li><br />
    <li><input type="radio" name="g5" value="0" />D. None of the above</li><br />
  </ul>
</li>

<li>Which of the following is a Client Script best practice?<br/>

  <ul type="none">
    <li><input type="radio" name="g6" value="0" />A. Use hard coded data</li><br />
    <li><input type="radio" name="g6" value="0" />B. Maximize server lookup</li><br />
    <li><input type="radio" name="g6" value="1" />C. Do not use g_form.getReference()</li><br />
    <li><input type="radio" name="g6" value="0" />D. All of the above</li><br />
  </ul>
 </li>

 <li>Which of the following are debugging features?<br/>


  <ul type="none">
    <li><input type="radio" name="g7" value="0"/>A. Debug Business Rule</li><br />
    <li><input type="radio" name="g7" value="0"/>B. Javascript</li><br />
    <li><input type="radio" name="g7" value="1"/>C. A and B</li><br />
    <li><input type="radio" name="g7" value="0"/>D. None of the above</li><br />
  </ul>
</li>


</ol>

document.querySelector()
适用于
ol
元素,因为只有一个元素。要捕获
ul
s,请使用
querySelectorAll
并循环相同的值。还有一个问题是
ol
ul
的父节点丢失。
parentNode.replaceChild…
语句必须位于
for
循环的后面,而不是内部。在
querySelectorAll
值上的循环中,必须备份父节点;看


你能发布你用来随机化列表的代码吗?旁注:如果你随机化列表,而“以上所有内容”在列表中排名第三,那么这是非常糟糕的做法。这是否包括第四种选择?另外,你不打算让A/B/C/D出现故障吗?那么,如果你不知道哪些字母会被标记为这些字母,你怎么会得到像“A和B”这样的答案呢?这还不完整,现在大概有50个问题,我只是想弄清楚如何将一堆列表随机排列,我发布了我必须随机化的代码。在你的第一个
for
循环中,你引用变量
ul
,而不是
ol
,这在当时已经定义。如果你使用单选按钮值,参加测试的人将能够从检查员那里查找正确答案!:PAh我明白了,非常感谢你,我觉得把孩子放在首位是有道理的。也不知道querySelectorAll()方法。
var ol = document.querySelector('ol');
temp = ol.cloneNode(true); 

for (var i = temp.children.length; i--; ){
    temp.appendChild( temp.children[Math.random() * i |0] );

    ul.parentNode.replaceChild(temp, ol); 
}

var ul = document.querySelector('ul');
temp = ul.cloneNode(true); 

for (var i = temp.children.length + 1; i--; ){
 temp.appendChild( temp.children[Math.random() * I |0] );

    ul.parentNode.replaceChild(temp, ul); 
}
    var ol = document.querySelector('ol');
    temp = ol.cloneNode(true);

    for (var i = temp.children.length; i--;) {
        temp.appendChild(temp.children[Math.random() * i | 0]);

    }
    ol.parentNode.replaceChild(temp, ol); 

    var ul = document.querySelectorAll('ul'), parent;
    console.log("found " + ul.length + " ul's");
    for (var k = ul.length-1; k >= 0; k--) {
        parent = ul[k].parentNode;
        temp = ul[k].cloneNode(true);

        for (var i = temp.children.length + 1; i--;) {
            temp.appendChild(temp.children[Math.random() * i | 0]);

        }
        parent.replaceChild(temp, ul[k]);
    }