使用 JQuery 填充 TinyMCE 文本区域(移动设备)
所以我初始化了我的文本区域,现在它是一个 TinyMCE 框......太棒了。
但我希望用户选择一些数据,然后用该数据填充该文本区域(顺便说一句,这是 HTML)...我使用此代码:
var text = file.rows.item(0).presentData;
if (text != null) {
text = text.replace(/\n/g, '<br />');
$('#editcontent').val(text);
#editcontent
是一个文本区域...这工作正常,直到我添加 TinyMCE。现在,当我点击此页面时,内容尚未填写。
有什么想法吗?
So I init my textarea and now its a TinyMCE box...great.
But I want the user to choose a some data and then fill in that textarea with that data (which is HTML btw) ... I was using this code:
var text = file.rows.item(0).presentData;
if (text != null) {
text = text.replace(/\n/g, '<br />');
$('#editcontent').val(text);
#editcontent
being a textarea... this worked fine until I added TinyMCE. Now when I hit this page, the contents are not filled in.
Any ideas?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
正如 Jasper 所说,首先填充文本区域。
TinyMCE 的作用是隐藏文本区域并在其位置放置一个可编辑的 Iframe。
如果您之前无法填充文本区域,则可以使用 firebug 或其他类似的解决方案检查实时代码,以查看 Ifram 获取的名称或 ID,或者您是否可以指定 id。
然后使用它来访问 Iframe。
As Jasper states, fill the textarea first.
What TinyMCE does is hide your textarea and place an editable Iframe in its place.
If you cannot fill the textarea before you might check you live code with firebug or some similar solution to see what the Ifram gets as name or ID or if you can specify an id.
Then use that to access the Iframe instead.
试试这个:
Try this:
设置文本区域的值后初始化 TinyMCE 实例怎么样?
我不确定这是否是初始化 TinyMCE 的方式,但如果您在
$('#editcontent').val(text)
行之后初始化它,那么它应该可以处理您的数据。您还可以“刷新”TinyMCE 实例的内容。
What about initializing the TinyMCE instance after you have set the value of your textarea?
I'm not sure if that's how you initialize TinyMCE but if you initialize it after the
$('#editcontent').val(text)
line then it should work with your data.You can also "refresh" the content of your TinyMCE instance.
我在加载时调用 init ,然后在填写文本后再次尝试执行此操作...最终对我有用的是在填写文本区域框后这样调用它。
I was calling init at the load and then tried to do it again after I filled in the text... what finally worked for me was to call it like that AFTER I filled in my textarea box.