Я не могу редактировать текст на слое после добавления нового слоя с помощью kineticjs

Я сделал это http://jsfiddle.net/62Wjc/5/, создаю и изменяю текст на слое, но это статично. Сейчас я делаю скрипт для динамического добавления полей + добавления слоя + изменения слоя.

На моем скрипте есть три функции, которые:

  1. функция CreateTxt для создания элемента и создания слоя с KineticJS.
  2. функция fRField для удаления элемента
  3. функция ChangeTxt для изменения текста на слое.

И это мой сценарий:

$(document).ready(function() {

    var nwValue = [];
    var nwLayer = {};
    var nwTxt = {};
    var tulisan = 'Your text here';
    var con = $('#idEditor');
    var cW = con.width();
    var cH = con.height();
    var stage = new Kinetic.Stage({
        container: 'idEditor',
        width: cW,
        height: cH
    });

    $('a[data-selector="get_new_txt"], a[data-selector="get_new_img"]').on('click', function(event){
        var time = new Date().getTime();
        var regexp = new RegExp($(this).data('id'), 'g');
        $('#nF').append($(this).data('fields').replace(regexp, time));
        CreateTxt(time);
        event.preventDefault();
    });

    $('#nF').on('click', 'a[data-selector="removeField"]', function(e) {
        var a = $(this);
        fRField(a);
        e.preventDefault();
    });

    $('#nF').on('keyup', 'input[data-selector="inputName"]', function() {
        var a = $(this);
        ChangeTxt(a);
    });

    function CreateTxt(idV) {
        var iclone = 0;
        nwValue.push(idV);
        $.each(nwValue, function( index, value ){
          nwLayer["layer"+ value] = new Kinetic.Layer();
        });

        stage.add(nwLayer["layer"+ idV]);
        $.each(nwValue, function( index, value ){
          nwTxt["text"+ value] = new Kinetic.Text({
                x: 100,
                y: 100,
                text: "Your text here",
                fontSize:18,
                fill: 'red',
                draggable: true,
                id: 'txt'+ value
            });
        });
        nwLayer["layer"+ idV].add(nwTxt["text"+ idV]);
        nwLayer["layer"+ idV].draw();      
    }

    function fRField(a){
      if(confirm('Are you sure to delete this field ?')) {
        a.prev("input[type=hidden]").value = "1";
        a.closest(".form-inline").remove();
      }
      return false;
    }

    function ChangeTxt(a){
        var dataid = a.attr('data-id');
        var newValue = a.val();
        nwTxt["text"+ dataid].setText(newValue);
        nwLayer["layer"+ dataid].draw();
    }

});

jsfiddle: http://jsfiddle.net/8oLsoo25/5/

После добавления нового текста я не могу сначала изменить текст на слое.

1 ответ

Решение

Ваш $.each звать nwValue разрушает вещи для вас. Если вы разместите nwValue = []; выше nwValue.push(idV); в CreateTxtвсе работает как положено. Другими словами, вы заменяете ссылки на оригинальные объекты. Кроме того, знаете ли вы, что новый слой в Kinetic означает новый элемент canvas в DOM?

Другие вопросы по тегам