1
テーブル内の項目の変更を保存し、対応する要素を<p>
から<textarea>
に変更して戻したいが、現在は更新されていない。ここでjqueryでテキストエリアに変更を保存するには
例 https://jsfiddle.net/rajjejosefsson/qmeogxgL/12/
JS
$("td").on('click', '.js-edit', function() {
$(this).text('Save Changes');
$(this).addClass('js-save');
var img = $(this).parent('td').parent('tr').find('.img-candy');
console.log(img);
var imgUrl = img.attr('src');
var tr = $(this).parent('td').parent('tr').find('td p').replaceWith(function() {
return $("<textarea />", '').append($(this).contents());
});
});
$("td").on('click', '.js-save', function() {
$(this).text('Edit');
$(this).removeClass('js-save');
var tr = $(this).parent('td').parent('tr').find('td textarea').replaceWith(function() {
return $("<p />", '').append($(this).contents());
});
var name = $(this).parent('td').parent('tr').find('.name-td').children('p').text();
var price = $(this).parent('td').parent('tr').find('.price-td').children('p').text();
var description = $(this).parent('td').parent('tr').find('.description-td').children('p').text();
var img = $(this).parent('td').parent('tr').find('.img-candy').attr('src');
var category_id = "a";
var item_id = "a";
});
使用 '$(この).val()'テキストエリアの値を取得するためです。 – Barmar
ちょうど私の自己によってそれを見つけたおかげで。 –