javascript - 如何将 Jodit 编辑器添加到动态添加的文本区域?
问题描述
我有这个 JavaScript:
j = 0;
function add_more_additional_field() {
$('#additional_options').append(
'<div class="form-group row mar-btm"><div class="col-md-3"><input type="hidden" name="af_no[]" value="' + j + '"><input type="text" class="form-control" name="af_title[]" value="" placeholder="Additional Title"></div><div class="col-md-7"><textarea class="form-control editor" name="af_options[]"></textarea></div><div class="col-md-1"><button onclick="delete_row(this)" class="btn btn-danger btn-icon"><i class="demo-psi-recycling icon-lg"></i>Remove</button></div></div><hr/>'
);
j++;
var editor = new Jodit('#additional_options .editor');
}
function delete_row(em) {
$(em).closest('.row').remove();
update_sku();
}
该脚本的功能是在单击时附加更多的表单字段。这段代码工作正常。现在我也想在每次点击时附加一个 Jodit 编辑器。我尝试通过赋予唯一的 id 或类来做到这一点(请参阅我j
在上面的代码中如何使用)。但是此代码仅在第一个文本区域附加 Jodit 编辑器,但不为其他文本区域添加它。
如何将编辑器附加到每个文本区域字段?
解决方案
以下行将始终针对该类的第一个元素editor
:
new Jodit('#additional_options .editor');
...当您想使用该类定位新的最后一个元素时。因此,使用将 DOM 元素传递给Jodit
构造函数的可能性。然后,您可以获取所有匹配项的节点列表,并获取最后一个,并将其传递给构造函数:
new Jodit([...document.querySelectorAll('#additional_options .editor')].pop());
推荐阅读
- docker - Docker 由 nginx、express、letsencrypt SSL 组成 502 Bad gateway
- docker - Vue UI 无法通过 docker-compose
- laravel - “找不到类 'App\Game\User'”即使更改了提供程序
- javascript - 构建一个忽略空格的动态正则表达式
- bash - 使用 CURL 将特殊字符作为 HTTP POST 传递
- ruby-on-rails - 无法让用户确认使用设计在生产中工作
- javascript - 在 html 中如何将 div 类内容(文本)传递给另一个类或 id?
- node.js - 如何获取对象在数组中的位置?
- angular - 同步 Angular 任务
- swift - swift函数动态应用参数