- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在寻找一种设置列表样式的方法,以便它们在 contentEditable 元素中进行编辑时使用用户设置的格式。具体来说,我希望能够以与 <li>
的其余部分相同的方式设置数字/元素符号的样式。内容。
根据我所做的测试,浏览器从不设置样式 <li>
直接标记(实际上控制数字/元素符号的样式)但始终放置 <font>
标记(或 <span>
如果 StyleWithCSS
)作为第一个子节点,使用它进行格式化。我已经尝试了一些想法来解决这个问题,但还没有成功:
<li>
以编程方式在这里,我尝试监听“DOMNodeInserted”,当一个 <li>
出现时标签被插入到DOM中,我查询了当前的fontName
, fontSize
, 和 foreColor
命令并将它们作为内联样式应用于 <li>
.
textarea.addEventListener('DOMNodeInserted', function (evt) {
if (evt.target.nodeName === 'LI') {
evt.target.style.color = queryCommandValue('foreColor');
evt.target.style.fontFamily = queryCommandValue('fontName');
evt.target.style.fontSize = queryCommandValue('fontSize');
}
}, false);
即使这样做,一旦您开始在列表项中键入内容,浏览器就会尝试“智能”并从 <li>
中删除样式, 将它们放入 <font>
(或 <span>
)标签。 :(
基于上面的尝试,我没有编写内联样式,而是为它们创建了一个规则,给出了 <li>
节点 ID,并将规则插入到样式表中。现在规则将控制 <li>
的样式,我可以使用 CSSOM 不断更新任何特定的 <li>
的风格。
这似乎工作得很好(有一些错误需要解决),但是,它完全破坏了 contentEditable 撤消堆栈。由于撤消命令仅绑定(bind)到 textContent
和其他格式化命令,无法“撤消”您在样式表中设置的样式。 (至少不是很直观,我已经考虑过如何做到这一点......)
<li>
中的变化的属性并保留它们对于这次尝试,我使用了新近可用的 MutationObserver http://www.w3.org/TR/dom/#mutationobserver在 DOM 级别 4 中可用。此观察者可以观察节点属性的变化,这些变化将在 MutationRecord 中传回。它甚至可以保存以前的属性值,包括 style
值,这样我就可以找出被删除的内容并重新应用它。
var observer = new WebKitMutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
if (mutation.target.nodeName === 'LI') {
...
}
})
});
observer.observe(document, {
attributes: true,
subtree: true,
attributeOldValue: true
});
这仍然缺乏撤消支持。您将撤消其他格式更改,但 <li>
我们将保持他们的风格。
有什么新颖的想法吗?仅限现代浏览器的解决方案也受到欢迎。我知道我可以格式化我自己的 HTML 以用于列表,但我正在尝试查看是否可以使用标准 insertOrderedList
来完成此操作。和 insertUnorderedList
使用真实列表标签的命令。
似乎还没有人解决过这个问题,这里有一个 JSFiddle 示例来查看我正在描述的内容:http://jsfiddle.net/8LyZR/ .只需尝试更改元素符号列表或编号列表的样式即可。
对于我正在从事的元素,我们正在使用我们自己构建的 WebKit,因此我们能够通过 native 更改来修复此问题,但我希望有一种方法(或将有一种方法)直接执行此操作使用 HTML/CSS/JS。
最佳答案
这里有一些有趣的 CSS 技巧。 http://jsfiddle.net/GZ3cv/
它基本上依赖于在内嵌标签上放置一个伪元素 :before
(这将继承样式),然后尝试将其放置在原始列表元素符号/数字的顶部。
我无法决定是否将此称为解决方案,因为嵌套/内联标签(font、u、b、span、i)的所有不同组合可能会变得不切实际。
但只是尝试使用字体、大小、颜色和列表类型控件,它似乎可以通过一些明显的彻底调整来模仿您正在寻找的内容。
我很好奇这种技术是合理的还是荒谬的:)把它扔在那里..
关于javascript - 使用字体系列、字体大小和颜色设置内容可编辑列表 (<li>),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10540862/
你知道更好的写法吗 font = font ? font : defaultFont; 我所知道的是: if(!font) { font = defaultFont } 我知道这是一个小工具问
我正在编写代码,但无法编译,即使类(字体)已通过 import javafx.scene.text.*; 导入我知道这个方法font包含在字体中。 这是我的代码: package helloworld
我已经构建了一个按钮,但在格式设置(即平方、内联文本等)方面遇到了问题 我目前的问题是:正文分为2部分- 上线正常-下一行是较大的字体大小 我的动画 react 正确,但文本应该在箭头的顶线和底线内。
好的,所以我想在网页上使用固定系统作为字体。我可以使用 Cufon,但我希望人们能够在鼠标悬停时选择文本并复制它。 有人有什么吗? 最佳答案 我使用 fontsquirrel 的 @font-face
我找到了 iOS 4.2 可用字体列表(链接 here ),但该列表与早期版本的 SDK 略有不同(链接 here )。 我可以很好地更改代码中的字体,但如果我使用 iOS 4.2 列表中可用的字体,
我正在尝试更改 TableView 标题上的字体颜色,其中显示“加利福尼亚/纽约”。我该怎么做? 在黑色背景上,文本需要是白色的,但无法弄清楚这一点。 谢谢 最佳答案 如果您尝试更改标题颜色,可以使用
假设我想使用 java.awt.Graphics.drawString(String str, int x, int y)在某些特定坐标处绘制字符串的方法,例如 (300, 300)。然而drawSt
我想使用Puppeteer从HTML字符串生成图像。现在我有这样的事情: const html = _.template(` Hello {{ test }}!
我正在创建一个游戏。我有一些带有文本的用户界面。最近我们想添加日语版本,但我遇到字体问题。我使用 stb_freetype 来光栅化字体,并且我支持 Unicode,所以这应该不是问题。但大多数字体似
我可以在一个文本区域中使用不同的前景色吗?不同的字体? 我想添加类似“hh:mm:ss 昵称:消息”的内容,时间为灰色,名称 - 蓝色,消息 - 黑色。 最佳答案 我在评论中犯了一个错误:你想要的是
每次我更改字体时,它都会返回到默认大小,即 12,即使我之前使用“ Jade 野”菜单更改它,它每次也只会返回到 12,我的猜测是这样我使用deriveFont()更改大小,但现在没有其他方法可以更改
我的电脑上安装了一种名为“BMW1”的自定义字体。我试图循环遍历此字体中的所有条目并将它们显示在 JTextArea 中。 我有以下代码: JTextArea displayArea = new JT
我尝试通过 Squirrel 理解生成的代码,这里是输出: @font-face { font-family: 'someFont'; src: url('someFont.eot')
我知道有多种方法可以通过 JS/DHTML 动态更改网页的字体属性,或者用 Flash 呈现的字体(使用 sIFR 或 Cufon)替换文本。但是,我找不到任何根据用户选择动态更改网页上使用的字体的好
使用具有非标准样式名称(例如“Inline”或“Outline”)而不是标准样式(例如“Bold”和“Italic”)的字体系列,如何使用 css 选择字体的不同样式? 设置 font-family
我对 html/css 有点陌生,我正在制作我的第一个网站,但我只是想不通一些东西。 首先,我在 dreaweaver 中工作...在 dreaweaver 中,一切看起来都不错,但是当我预览时,我缺
有没有办法在 Allegro5 中只绘制(或显示)图像/字体的一部分? 例如,如果我有一个正方形 A 和一个图像 B,我只想绘制/显示 B 中与 A(在本例中为 C)重叠的部分,我该怎么做? 插图:
所以,我有一个正在生成的报告 html 文件,其中有需要白色文本/字体的黑框。在通用 html 显示中一切都很好,但是当我尝试打印页面时,ctrl + p 或自定义打印功能,文本/字体保持为标准颜色,
我正在尝试制作一个非常适合 LaTeX 文档的 matlab 图形。一个已知的问题是 XTickLabel 和 YTickLabels 不使用 LaTeX 解释器渲染,导致图形不好看。 (注意:我意识
我需要在一个公共(public)位置使用默认颜色和字体,以便在桌面应用程序的多个窗口窗体中使用它。 这方面的最佳做法是什么? 我正在考虑使用应用程序设置在那里定义它们,但我想确保这是推荐的方法或者是否
我是一名优秀的程序员,十分优秀!