Mootools注入代码修改它为.each

时间:2012-05-16 08:30:29

标签: mootools selector inject

我有以下html。

<ul>
<li>
    <label id="firstswitch-lbl" class="hasTip">My First Selector:</label>
    <select id="first_switch" class="switch">
        <option value="0">Enable</option>
        <option selected="selected" value="1">Disable</option>
    </select>
</li>
<li>
    <label id="first_title-lbl" class="hasTip">First Select:</label>
    <input id="first_title" class="text" type="text" size="3" value="50">
</li>
<li>
    <label id="secondswitch-lbl" class="hasTip">My Second Selector </label>
    <select id="second_switch" class="switch">
        <option value="0">Enable</option>
        <option selected="selected" value="1">Disable</option>
    </select>
</li>
<li>
    <label id="second_title-lbl" class="hasTip">Second Select:</label>
    <input id="second_title" class="text" type="text" size="3" value="100">
</li>
<li>
    <label id="thirdswitch-lbl" class="hasTip">My Third Selector </label>
    <select id="third_switch" class="switch">
        <option value="0">Enable</option>
        <option selected="selected" value="1">Disable</option>
    </select>
</li>
<li>
    <label id="third_title-lbl" class="hasTip">Third Select:</label>
    <input id="third_title" class="text" type="text" size="3" value="200">
</li>
<li>
    <label id="fourthswitch-lbl" class="hasTip">My Fourth Selector </label>
    <select id="fourth_switch" class="switch">
        <option value="0">Enable</option>
        <option selected="selected" value="1">Disable</option>
    </select>
</li>
<li>
    <label id="fourth_title-lbl" class="hasTip">Fourth Select:</label>
    <input id="fourth_title" class="text" type="text" size="3" value="200">
</li>

跟随mootools javascript工作正常。

    document.id('first_switch').inject(document.id('first_switch').getParent().getNext(), 'bottom');
document.id('first_title').getParent().getPrevious().dispose();
document.id('second_switch').inject(document.id('second_switch').getParent().getNext(), 'bottom');
document.id('second_title').getParent().getPrevious().dispose();

但是我试图减少重复相同代码的次数,因为我有大约20个或更多相似的行,所以我希望使用.each函数缩短或更简化,但只是无法弄明白。

我正在尝试在Selector旁边添加值框,以便它们位于同一行而不是使用两行。任何帮助高度赞赏。提前谢谢。

以下是Fiddle Example Code

的链接

1 个答案:

答案 0 :(得分:0)

你应该稍微调整一下,但是:

document.getElements("li input.text").each(function(input) {
    var parent = input.getParent("li");
    input.inject(parent.getPrevious().getFirst(), "after");
    parent.destroy();
});

这将循环整个页面,因此我建议document.id("ulel").getElements

http://jsfiddle.net/dimitar/GzVca/1/