Я хотел бы получить следующую структуру:
[gfhtfg..., kgjrfg..., asd, mrhgf, ]
^-------^ ^-------^ ^-------^ ^-------^
X X X X
(X = a fixed length)
У меня есть <div>
с фиксированной длиной и внутри него горизонтальный, разделенный запятыми список (ul
) ссылок.
Элементы <li>
должны иметь фиксированную ширину, поэтому, если ссылки превышают фиксированную длину, будет отображаться многоточие (с использованием свойства text-overflow
).
Я знаю два способа сделать список горизонтальным. Один использует display: inline
, а другой - свойство float
.
- При первом подходе я не могу установить фиксированную ширину, потому что спецификация CSS не позволяет устанавливать ширину встроенных элементов.
- Второй подход создает беспорядок: O
- Установка
float
для элемента <a>
с намерением ограничить ширину там отделяет его от запятых.
Нет проблем с совместимостью браузера, мне нужно только поддерживать WebKit.
Я включил код, с которым пытался работать:
<!DOCTYPE html>
<html lang="en">
<head>
<title>a title</title>
<style>
body { font-family: arial; font-size: 10pt; }
div {
height: 30px;
width: 300px;
background: #eee;
border: 1px solid #ccc;
text-align: center;
}
ul { margin: 0px; padding: 0px; }
ul li:after { content: ","; }
ul li:last-child:after { content: ""; }
ul li a { text-decoration: none; color: #666; }
ul li {
margin: 0px;
padding: 0px;
list-style: none;
overflow: hidden;
text-overflow: ellipsis;
-webkit-text-overflow: ellipsis;
/* Inline elements can't have a width (and they shouldn't according to the specification */
display: inline;
width: 30px;
}
</style>
</head>
<body>
<div>
<ul>
<li><a href="#">a certain link</a></li>
<li><a href="#">link</a></li>
<li><a href="#">once again</a></li>
<li><a href="#">another one</a></li>
</ul>
</div>
</body>
</html>
Спасибо.