contenteditable 元素的placeholder

168 篇文章 11 订阅 ¥39.90 ¥99.00

假设我们希望给定contenteditable元素有一个占位符:

<div contenteditable></div>

1.使用:empty选择器

我们使用自定义属性 ,data-placeholder来设置占位符:
<div class="editable" contenteditable data-placeholder="Edit me"></div>

当元素值为空时,将显示该属性:

.editable:empty:before {
    content: attr(data-placeholder);
}

2. 处理事件

首先,我们将iddata-placeholder属性添加到元素中,如下所示:
<div contenteditable data-placeholder="Edit me" id="editMe"></
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
如果你想在保留`contenteditable="true"`和`oninput="filterTable(1)"`属性的同时实现表单提交功能,你可以使用JavaScript来处理表单提交。 首先,在`<form>`标签中添加一个`onsubmit`事件处理程序,用于在表单提交时执行自定义的JavaScript函数。例如: ```html <form action="insert.php" method="POST" onsubmit="submitForm(event)"> <table> <tr> <td contenteditable="true"><input type="text" oninput="filterTable(1)" placeholder="aoiStep"></td> <td contenteditable="true"><input type="text" oninput="filterTable(2)" placeholder="defectType"></td> <td contenteditable="true"><input type="text" oninput="filterTable(3)" placeholder="layerCode"></td> <td contenteditable="true"><input type="text" oninput="filterTable(4)" placeholder="type"></td> <td contenteditable="true"><input type="text" oninput="filterTable(5)" placeholder="dpet"></td> <td contenteditable="true"><input type="text" oninput="filterTable(6)" placeholder="subcode"></td> <td contenteditable="true"><input type="text" placeholder="codeDescription"></td> <td contenteditable="true">image1</td> <td contenteditable="true">image2</td> <td contenteditable="true">image3</td> <td contenteditable="true">image4</td> <td contenteditable="true">image5</td> <td contenteditable="true"><input type="text" placeholder="determination_rule"></td> </tr> </table> <input type="submit" value="Submit"> </form> ``` 接下来,创建一个JavaScript函数`submitForm(event)`来处理表单的提交事件。在该函数中,你可以阻止表单的默认提交行为,并获取表单中的数据进行处理。例如: ```javascript function submitForm(event) { event.preventDefault(); // 阻止表单的默认提交行为 var form = event.target; // 获取表单元素 // 获取表单中的数据 var aoiStep = form.querySelector('[placeholder="aoiStep"]').value; var defectType = form.querySelector('[placeholder="defectType"]').value; var layerCode = form.querySelector('[placeholder="layerCode"]').value; var type = form.querySelector('[placeholder="type"]').value; var dpet = form.querySelector('[placeholder="dpet"]').value; var subcode = form.querySelector('[placeholder="subcode"]').value; var codeDescription = form.querySelector('[placeholder="codeDescription"]').value; var determinationRule = form.querySelector('[placeholder="determination_rule"]').value; // 执行你想要的数据处理操作 // ... // 提交表单 form.submit(); } ``` 在上述代码中,我们首先使用`event.preventDefault()`来阻止表单的默认提交行为。然后,通过`event.target`获取到提交事件所在的表单元素。 接下来,我们使用`form.querySelector`方法来获取到每个输入字段的值,并将其存储在相应的变量中。 最后,你可以在`submitForm`函数中执行你想要的数据处理操作,例如验证、发送AJAX请求等。 最后,我们调用`form.submit()`方法来提交表单。 通过以上步骤,你可以在保留`contenteditable="true"`和`oninput="filterTable(1)"`属性的同时实现表单提交功能。 希望这个解决方案对你有帮助。如有任何疑问,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

紫微前端

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值