- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试让我们的 CMS 编辑器能够仅使用 css 覆盖来替换用于页面标题的文本。
<header data-alternate="An Alternate Title">
This Page's Default Title
</header>
使用 :before 或 :after 标签,可以使用许多可用的备用标题之一。
header:before {
content: attr(data-alternate);
display: inline-block;
}
如果我们也可以说,
header:text {
display: none;
}
不幸的是,据我所知,没有很好的方法来隐藏“此页面的默认标题”以将其替换为“备用标题”。如果这是一个 Sprite,我们可以使用一种陈旧的图像替换技术,如 Phark 或其他。 :before 生成的文本替换不是那么多,因为 :before 也受到用于隐藏默认文本的 CSS 设备的影响,因此,例如,对于 Phark,:before 内容也在 -9999px。
有些解决方案我正在努力避免。
即
<header data-alternate="An Alternate Title">
<span class="default">This Page's Default Title</span>
</header>
这可行,但嵌套在 header 中的跨度令人不快。
有没有一种方法可以定位标签的文本而不同时定位其生成的 :before/:after 内容?还有其他方法吗?
最佳答案
我不确定这是否正是你想要的,但你可以尝试这样的事情:
p {
visibility: hidden;
}
p:before {
content: attr(data-alternate);
display: inline-block;
visibility: visible;
}
您可以将 p
元素的可见性设置为隐藏,然后将 :before
伪元素的可见性设置为在其父元素中可见( p
) 尽管它正在设置。
如果这不能完全按预期工作,那么添加一个额外的跨度来帮助这个过程并没有什么大错。它可能不那么干净,但可以更好地工作。
但是,我确实想提出一个问题,即为什么您可能需要这样做,并指出对这种方法的一些担忧...
对于初学者来说,伪元素不是 DOM 的一部分,因此无法选择替代文本,浏览器(或用户)也无法访问它。屏幕阅读器或搜索引擎将看到默认文本,而不会注意替代文本,但这就是您的用户将看到的...这可能会导致一些困惑。
虽然您的问题指定您希望能够使用 CSS 来执行此操作,并且虽然这可能是可能的,但它确实不是执行此类操作的最佳解决方案。特别是如果您的网站在不支持伪元素的旧浏览器中查看(现在用户什么也看不到!)。
我更推荐这样的东西,用于将图像换成打印样式表中的替代文本,或者将超链接的文本换成它链接的完整地址(同样,主要用于打印样式表)。以这种方式更改标题等重要内容可能会导致许多其他问题,尤其是在可访问性方面。
只是让您考虑我的回答...希望我已经帮助您解决了您的问题!
关于css - 如何使用生成的 :before or :after without absolute positioning? 进行 CSS 文本替换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22824119/
我刚开始使用 html5 和 css,我对使用 css position 有点困惑。 我可以从堆栈溢出中找到这些链接, Difference between relative and absolute
我想知道是否有一种方法可以获得相对定位的元素的“绝对位置”。我想不出任何方法,但也许有人想出了一个方法...... 最佳答案 我不确定“绝对位置”是什么意思,但您可以使用 el.getBounding
基本上我的 HTML(使用 Bootstrap 类)中有一个页面,其中包含使用 thumbnail 和 caption 类展示的产品。在产品图片上方有一个 ON SELL(圆形红色标签)。我给这个红色
当我使用 BaseAdapter 的 ListView 离开屏幕时,每一行不再保持连续的位置。除了这个我不知道还能怎么解释。 如果我的 BA/LV 在屏幕上显示 4 个项目,并且我添加了一个显示每一行
此 HTML 无法在 IE8 中正确呈现。它适用于 Firefox、Opera、IE7、IE9 和 IE10。 (当然,它在 IE6 中也不起作用,因为它涉及固定位置的元素。) 实际上它在 Chrom
我正在使用Position Absolute的表单验证引擎。 我有一个特定的验证案例,希望可以为我解决。我需要能够根据另一个字段的值来使一个字段成为必需。 例如: If country.dropdow
我看过很多帖子,人们希望将相机位置调整到屏幕位置。我的问题是如何做相反的事情。 我目前想要实现的是将“门”位置设置为屏幕的百分比,此计算已准备就绪,并且我确实有最终屏幕的 X、Y (px) 位置。相机
谁能解释一下使用 position:relative、position:absolute 和 float 对正常文档流及其子项的影响的区别? 例如当我有三个元素 A、B、C 时,其中 A 是包含 B
我有以下代码: .tabs{ position: fixed; top:110px; left:0px; width:40px; z-inde
我不知道如何表达这个问题。 所以这是一个例子。 图层上的动画滑入 View ,然后稍微弹回。 十分简单。 位置关键帧看起来像这样: 关键帧 0:(-100,200) 关键帧 10:(100,200)
我是 XSLT 的新手,我正在使用 w3schools 的“自己尝试”页面进行一些测试。我正在使用以下演示: http://www.w3schools.com/xsl/tryxslt.asp?xmlf
我试图让一个对象 1 (SKSpriteNode) 在某个高度(y 坐标)处创建另一个对象 (object2)。我已经得到了我需要的所有代码,除了我不知道如何正确编写: object1.positio
.special p { display:none; } .special:hover p { display:block; } Things
当将一个绝对定位元素放置在一个位置固定包装器中时,在一个位置相对包装器中,绝对元素位置不应该相对于相对 parent 而不是固定 parent ? Content
我有一个 iframe,它在应用 css 后显示谷歌地图 position: relative; top: 48px; left: -233px; 但是当我向下滚动时,它刚好出现在显示 khaleej
我在一个网站上工作,有一个带有 position:relative 的父元素,它有一个带有 position:absolute 的子元素。令我感到奇怪的是,对于我提到的位置,子元素似乎仍然可以识别它们
我有一个 main 元素,我已将其设置为 position: relative。这包含两个 div,然后我在其上应用 position: absolute。然后,这会导致夹在 main 元素中间的页眉
HTML 代码由一个 div 组成,它具有两种类型的类:“隐藏”和“保留”。 Lorem ipsum dolor sit amet, consectetur adipis
我必须开发一个生成表格(有点……)的软件,并且必须提供对元素位置的完全控制。 到目前为止,我们有这样的构造: 还有一些javascript代码来放置#a , #b和 #c #co
我尝试将 z-index 设置为 body 下的某些位置为 fixed 的元素 示例如下: HTML menu content ....
我是一名优秀的程序员,十分优秀!