如何使用 CSS 和 attr() 在元素的 ::before 中插入换行符

问题描述 投票:0回答:1

我的问题类似于堆栈溢出中的thisone。但有一个区别。我想在“::before”伪元素的“content”中的“attr()”函数中有换行符。我的代码是这样的:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        div > a {
            white-space: pre-wrap;
        }
        div > a::before {
            display: block;
            content: attr(title);
        }
    </style>
</head>
<body>
<div><a href="#" title="Facebook Ads \A Performance Grader Get  ready to improve your reach …">actual link</a></div>
</body>
</html>

我想在 “a” 标签的“title”属性中的文本中换行。因此,根据这个问题,我在“标题”属性中使用了

\A
。但这是行不通的!在这种情况下不会发生换行。我想知道这是为什么?当我在 CSS 中使用“
attr()
”函数时,我的文本中怎么会有“换行”(制作新行)?如果我只是在 CSS 的“content”属性中使用真实文本,如下代码所示:

div > a::before {
            display: block;
            
            content: "Facebook Ads \A Performance Grader Get  ready to improve your reach …";
        }

效果很好。但是当使用“attr()”时,它不起作用!

html css
1个回答
0
投票

在 HTML 中,您需要使用 ascii 代码

&#10;
(或类似的)

div > a {
  white-space: pre-wrap;
}

div > a::before {
  display: block;
  content: attr(title);
}
<div><a href="#" title="Facebook Ads &#10; Performance Grader Get  ready to improve your reach …">actual link</a></div>

© www.soinside.com 2019 - 2024. All rights reserved.