我的问题类似于堆栈溢出中的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 中,您需要使用 ascii 代码
(或类似的)
div > a {
white-space: pre-wrap;
}
div > a::before {
display: block;
content: attr(title);
}
<div><a href="#" title="Facebook Ads Performance Grader Get ready to improve your reach …">actual link</a></div>