我正在创建一个系统,用户可以在其中预览配方的标题和步骤,我已经创建了一个动态表单,以便用户可以添加更多步骤,该预览适用于标题和第一步,但是似乎无法它可以进行第二,第三,第四步。谁能帮我?任何帮助将不胜感激!
http://jsfiddle.net/uKgG2/
jQuery的
var commentNode = $('#lp-step'),
nameNode = $('#lp-name');
$('input, textarea').bind('blur keyup', function () {
commentNode.html($('textarea[name="step_detail[]"]').val().replace(/\n/g, '<br />'));
nameNode.text('Title: ' + $('input[name="name"]').val());
});
var addDiv1 = $('#addStep');
var i = $('#addStep p').size() + 1;
$('#addNewStep').on('click', function () {
$('<p> <textarea id="step_' + i + '" name="step_detail[]"> </textarea><a href="#" class="remNew1">Remove</a> </p>').appendTo(addDiv1);
i++;
return false;
});
$(document).on('click', '.remNew1', function () {
if (i > 2) {
$(this).parents('p').remove();
i--;
}
return false;
});
的HTML
<label for="name">Enter recipe name:</label>
<input type="text" name="name">
<br />
<h1>Method</h1>
<div id="addStep">
<p>
<textarea id="step_1" name="step_detail[]"></textarea>
<a href="#" id="addNewStep">Add</a>
</p>
</div>
<br />
<button type="submit">
Save on xml
</button>
</form>
<div id="live-preview-display">
<div id="lp-name"> </div>
<div id="lp-step"> </div>
</div>
最佳答案
您应该将keyup
或blur
事件绑定到所有用add
按钮创建的新文本区域,或链接任何内容。
已改善
尝试这个 :
$('#addStep').on('keyup', 'textarea', function () {
step_id = $(this).attr('id');
step_text = $('#' + step_id).val();
if($('.'+step_id).length > 0) {
$('.'+step_id).text(step_text);
return;
}
p = document.createElement('p');
p.className = step_id;
$(p).appendTo(commentNode);
$(p).text(step_text);
});
有效!我也把它保存起来。您应该只更新
recipe name
并清理它,因为我说我不是很hacky,只是需要改善它。祝您好运。 http://jsfiddle.net/uKgG2/3/