我对编辑功能有一个特别的想法

时间:2015-02-17 12:54:13

标签: javascript jquery list select edit

以下所有功能都在$(文件).ready(function())下!

首先,我有一个输入,你可以淡入/淡出它的样子:

<form>
        <label for="vorname"> Vorname: </label> <input type="text" id="vorname"/></br>
        <label for="nachname"> Nachname: </label> <input type="text"  id="nachname"/></br>
        <label for="alter">Alter:</label> <input type="number" Id="alter"/></br>

        <label for="gender">Geschlecht:</label>
            <select id="geschlecht">
                <option id="Male">männlich</option>
                <option id="Female">weiblich</option>
            </select>
        <input type="button" value="Zurückklappen" id="back"> //fadeOut
        <input type="button" value="Absenden" class="send"/> //eventhandler
    </form>

然后我有一个点击处理程序来创建列表条目

$('.send').click(function onClick(){ 

    var age = $('#alter').val();
    var preName = $('#vorname').val();
    var secName = $('#nachname').val();         
    var gender = $('#geschlecht').val();

    list.push ({
        alter: age,
        vorname: preName,
        nachname: secName,
        geschlecht: gender,
    });

    generateList();
    stat();
    save();
});

但是我想要一个获取所选列表条目的编辑功能

$("#liste").click(function selectList (event) {
        var target = $( event.target );
        if ( target.is( "li" ) ) {
            target.toggleClass('selected');
        }
    });

准确地说这一个(因为我不能一次编辑两个,或者我可以吗?也会很酷)选择Entry来编辑它。

这是我需要帮助的地方(以前的事情只是解释,在那里完成工作)。

        $(".edit").click(function (){

                var index = $('.selected')
    //this where the magic i think should
// happen somehow i must get an Index form the selcted list entry

                function edit(index) { 

        // here fadeIN the form which is shown above.
                        $( "#block" ).fadeIn(500);  
        $( "#block" ).animate({width: '54.4%', opacity: '0.8',fontSize: '1.5em'}, 750);
        $( "#block" ).animate({height: '40%', opacity: '0.8', fontSize: '3em'}, 750);



//this is my Idea:


//I want to call the already exsiting click function with an Index
//inside the edit function.
//so the function conitnues like this:

                        $('.send').click(function onClick(index){


                        var age = $('#alter').val(index);
                        var preName = $('#vorname').val(index);
                        var secName = $('#nachname').val(index);            
                        var gender = $('#geschlecht').val(index);

                        liste[index].push = {
                            vorname: preName,
                            nachname: secName,
                            alter: age,
                            geschlecht: gender
                        };


                        generateList();
                        save();
                    });
                } 

            });

如果需要,我可以发布整个程序。它可能是(或{在这么多代码中缺失,但我在我的程序中告诉你一切都是正确的。

1 个答案:

答案 0 :(得分:0)

目前它看起来像这样:

$("#liste").click(function selectList (event) {
    var target = $( event.target );
    if ( target.is( "li" ) && !$("li").hasClass('selected')) {
        target.addClass('selected');
    }
    else if (target.is( "li" ) && $("li").hasClass('selected')) {
        target.removeClass('selected');
    }
});

$('.deleteSel').click(function delSelectedEntries () {
    alert("Ausgewählte Beiträge wuden gelöscht");
    var sel = $('.selected'); //stores the entrys 
    sel.remove(); // removes only the list entrys temporaly
});

$(".edit").click(function editSelectedEntries(){    
    var index = $('.selected').attr("index");
    edit(index);
});

编辑功能:

function edit (index){

    $( "#block" ).fadeIn(500);  
    $( "#block" ).animate({width: '54.4%', opacity: '0.8',fontSize: '1.5em'}, 750);
    $( "#block" ).animate({height: '40%', opacity: '0.8', fontSize: '3em'}, 750);

    $('#alter').val(list[index].alter);
    $('#vorname').val(list[index].vorname);
    $('#nachname').val(list[index].nachname);   
    $('#geschlecht').val(list[index].geschlecht);

    $('.send').click(function onClick(){ 

        var age = $('#alter').val(); 
        var preName = $('#vorname').val();
        var secName = $('#nachname').val();         
        var gender = $('#geschlecht').val();

        list[index] = {
            vorname: preName,
            nachname: secName,
            alter: age,
            geschlecht: gender
        };

        generateList();
    });