如何使 xul 文件中的 div 内容可编辑(Firefox 扩展)?

发布于 2024-11-17 05:31:45 字数 1575 浏览 4 评论 0原文

这是我在 stackoverflow 上遇到的第一个问题,但我已经多次来这里解决其他问题,但我找不到这个问题的答案:How do I make a div contentEditable in an x​​ul file for a Firefox Extension ?

-以下是我的 .xul 文件的一部分,其中包含我想要内容可编辑的 div:

<page id="sbEmptySidebar" title="&emptysidebar.title;"
     xmlns:html="http://www.w3.org/1999/xhtml">
<vbox flex="1">
<label id="atest" value="&emptysidebar.title;" />
</vbox>
<html:div contentEditable value="Tryitout" style="width:150px;height:200px"/>
<html:input type="button" value="Bold" onclick="document.execCommand('bold',false,null);"/>
</page>

当我这样做时,我在扩展的侧栏中收到以下错误:

XML Parsing Error: not well-formed<br/>
Location: chrome://emptysidebar/content/emptysidebar.xul<br/>
Line Number 41, Column 29:<br/>
`<html:div contentEditable value="Tryitout"style="width:150px;height:200px"/>
-------------------------------^`

我发现了一些 div 是这样完成的示例,这里不只是说 contentEditable,而是说 contentEditable="true":

<page id="sbEmptySidebar" title="&emptysidebar.title;"
xmlns:html="http://www.w3.org/1999/xhtml">
<vbox flex="1">
<label id="atest" value="&emptysidebar.title;" />
</vbox>
<html:div contentEditable="true" value="Tryitout" style="width:150px;height:200px"/>
<html:input type="button" value="Bold" onclick="document.execCommand('bold',false,null);"/>
</page>

当我这样做时,我没有收到任何错误,但除了一个空白的 150x200 像素框之外什么也没有显示。我是否遗漏了一些东西,使 Firefox 扩展的 xul 文件中的 contentEditable div 成为可能?

This is my first ever question on stackoverflow, but I have made quite a few trips here to solve other problems, but I can't find an answer for this one: How do I make a div contentEditable in an xul file for a Firefox Extension?

-The following is the part of my .xul file which contains the div I want contentEditable:

<page id="sbEmptySidebar" title="&emptysidebar.title;"
     xmlns:html="http://www.w3.org/1999/xhtml">
<vbox flex="1">
<label id="atest" value="&emptysidebar.title;" />
</vbox>
<html:div contentEditable value="Tryitout" style="width:150px;height:200px"/>
<html:input type="button" value="Bold" onclick="document.execCommand('bold',false,null);"/>
</page>

When I do this, I receive the following error in the sidebar of my extension:

XML Parsing Error: not well-formed<br/>
Location: chrome://emptysidebar/content/emptysidebar.xul<br/>
Line Number 41, Column 29:<br/>
`<html:div contentEditable value="Tryitout"style="width:150px;height:200px"/>
-------------------------------^`

I have found some examples in which the div is done this way, where instead of just saying contentEditable you say contentEditable="true":

<page id="sbEmptySidebar" title="&emptysidebar.title;"
xmlns:html="http://www.w3.org/1999/xhtml">
<vbox flex="1">
<label id="atest" value="&emptysidebar.title;" />
</vbox>
<html:div contentEditable="true" value="Tryitout" style="width:150px;height:200px"/>
<html:input type="button" value="Bold" onclick="document.execCommand('bold',false,null);"/>
</page>

When I do that, I do not receive any errors, but nothing is displayed but a blank 150x200 pixel box. Is there something I am missing that makes a contentEditable div possible in an xul file for a Firefox Extension?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

许久 2024-11-24 05:31:45

您在这里使用的是 XHTML,而不是 HTML。它必须遵循 XML 规则,并且 XML 不支持属性最小化,请参阅 http: //www.w3.org/TR/xhtml1/#h-4.5。您应该使用完整的形式:

<html:div contentEditable="contentEditable" ...

也就是说,如果 contentEditable 在 XUL 中无法正常工作,我不会感到惊讶 - XUL 中嵌入的 HTML 通常不会执行预期的操作。最好使用 标记,将 HTML 文件加载到其中(例如 about:blank)并设置 document.designMode = "on “ 在本文档中。

What you are using here is XHTML, not HTML. It has to follow the rules of XML and XML doesn't support attribute minimization, see http://www.w3.org/TR/xhtml1/#h-4.5. You should use the full form instead:

<html:div contentEditable="contentEditable" ...

That said, I wouldn't be surprised if contentEditable isn't working correctly in XUL - HTML embedded in XUL is often not doing what's expected. It might be better to use an <iframe> tag, load an HTML file into it (e.g. about:blank) and set document.designMode = "on" on this document.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文