Я не могу редактировать текст на слое после добавления нового слоя с помощью kineticjs
Я сделал это http://jsfiddle.net/62Wjc/5/, создаю и изменяю текст на слое, но это статично. Сейчас я делаю скрипт для динамического добавления полей + добавления слоя + изменения слоя.
На моем скрипте есть три функции, которые:
- функция
CreateTxt
для создания элемента и создания слоя с KineticJS. - функция
fRField
для удаления элемента - функция
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?