使用Ajax将内容可编辑的内容更改另存为JSON

具有contenteditable属性的元素可以直接在浏览器窗口中进行实时编辑。 但是,这些更改当然不会影响服务器上的实际文档,因此这些更改不会随着页面刷新而持续。

保存数据的一种方法是等待按下返回键,然后触发该触发,然后将元素的新innerHTML作为Ajax调用发送并模糊该元素。 按Escape键可将元素返回到其预编辑状态。

document.addEventListener('keydown', function (event) {
  var esc = event.which == 27,
      nl = event.which == 13,
      el = event.target,
      input = el.nodeName != 'INPUT' && el.nodeName != 'TEXTAREA',
      data = {};

  if (input) {
    if (esc) {
      // restore state
      document.execCommand('undo');
      el.blur();
    } else if (nl) {
      // save
      data[el.getAttribute('data-name')] = el.innerHTML;

      // we could send an ajax request to update the field
      /*
      $.ajax({
        url: window.location.toString(),
        data: data,
        type: 'post'
      });
      */
      log(JSON.stringify(data));

      el.blur();
      event.preventDefault();
    }
  }
}, true);

function log(s) {
  document.getElementById('debug').innerHTML = 'value changed to: ' + s;
}

请参阅CodePen上的Chris Coyier@chriscoyier撰写的Pen Contenteditable / JSON / Ajax保存

翻译自: https://css-tricks.com/snippets/javascript/saving-contenteditable-content-changes-as-json-with-ajax/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值