text-overflow:ellipsis; hanya berfungsi jika yang berikut ini benar:
- Lebar elemen harus dibatasi dalam
px(piksel). Lebar dalam %(persentase) tidak akan berfungsi.
- Elemen harus memiliki
overflow:hiddendan white-space:nowrapmengatur.
Alasan Anda mengalami masalah di sini adalah karena elemen widthAnda atidak dibatasi. Anda memang memiliki widthpengaturan, tetapi karena elemen diatur ke display:inline(yaitu default) itu mengabaikannya, dan tidak ada yang membatasi lebar juga.
Anda dapat memperbaikinya dengan melakukan salah satu dari yang berikut:
- Atur elemen ke
display:inline-blockatau display:block(mungkin yang pertama, tetapi tergantung pada kebutuhan tata letak Anda).
- Atur salah satu elemen penampungnya
display:blockdan beri elemen tersebut perbaikan widthatau max-width.
- Atur elemen ke
float:leftatau float:right(mungkin yang pertama, tetapi sekali lagi, salah satu harus memiliki efek yang sama sejauh menyangkut elipsis).
Saya sarankan display:inline-block, karena ini akan memiliki dampak jaminan minimum pada tata letak Anda; ini bekerja sangat mirip dengan display:inlineyang digunakan saat ini sejauh menyangkut tata letak, tetapi jangan ragu untuk bereksperimen dengan poin lain juga; Saya sudah mencoba memberikan info sebanyak mungkin untuk membantu Anda memahami bagaimana hal-hal ini berinteraksi bersama; sebagian besar pemahaman CSS adalah tentang memahami bagaimana berbagai gaya bekerja bersama.
Berikut cuplikan dengan kode Anda, dengan display:inline-blocktambahan, untuk menunjukkan seberapa dekat Anda.
.app a {
height: 18px;
width: 140px;
padding: 0;
overflow: hidden;
position: relative;
display: inline-block;
margin: 0 5px 0 5px;
text-align: center;
text-decoration: none;
text-overflow: ellipsis;
white-space: nowrap;
color: #000;
}
<div class="app">
<a href="">Test Test Test Test Test Test</a>
</div>
Referensi yang berguna: