3

純粋な Javascript で div を複製しようとしていますが、cloneNode によって ID (div_0) が重複します。id を div_1, div_2... のようにインクリメントし、somevar = {'elem', 'div_1'} にも同じことをしたいと思います... ありがとう

<html>
<head></head>
<body>
<div id="mydiv">
    <div id="div_0">
        <script type="text/javascript">
            <!--
            somevar = {'elem', 'div_0'};
            //-->
        </script>
        <p>HELLO</p>
    </div>
</div>

<a href="#" onclick="cloning()">CLONE</a>

<script type="text/javascript">
    function cloning() {
        var container = document.getElementById('mydiv');
        var clone = document.getElementById('div_0').cloneNode(true);
        container.appendChild (clone);
    }
</script>
</body>
</html>
4

3 に答える 3

4

これを試して..

`

function cloning() {
    var container = document.getElementById('mydiv');
    var clone = document.getElementById('div_0').cloneNode(true);
    clone.setAttribute('id','div_'+document.getElementById('mydiv').getElementsByTagName('div').length);
    container.appendChild (clone);
}

`

于 2011-01-11T17:40:59.603 に答える
1

呼び出しごとに設定counter=0してインクリメントし、使用して設定しますcloningcounter++clone.id'div_' + counter

于 2011-01-11T17:08:17.390 に答える
0

これをテストする機会はありませんでしたが、これでうまくいくかもしれません:

function cloning (e) {
    if (typeof e === 'string') {
        e = document.getElementById(e);
    }

    var clone = e.cloneNode(true),
        last_inc = cloning.last_inc || parseInt(e.id.match(/(\d+)$/)[0], 10);

    last_inc += 1;

    clone.id = 'div_' + last_inc;
    cloning.last_inc = last_inc;

    e.parentNode.appendChild(clone);
}

どこかでグローバル変数を更新したい場合return { "elem" : "div_" + last_inc };は、関数の結果を実行して割り当てることができます。または、返品の代わりに、明示的に割り当てを行うこともできます。私は前者をお勧めします。

于 2011-01-11T17:58:40.083 に答える