У меня есть div
с некоторым текстом, который изначально не переносится и показывает многоточие, но я хочу дать пользователю возможность щелкнуть опцию «Читать дальше», а затем развернуть div, чтобы отобразить весь фрагмент текста.
Однако я хочу иметь возможность определить, достаточно ли мал текст, чтобы поместиться в div, без необходимости расширять его из одной строки, и если это так, скройте параметр «Показать больше».
Вот ссылка на модифицированный JS Fiddle, над которым я работаю:
И код из него:
$(document).bind('pageshow', function() {
$(".text-size").click(function() {
$(".ui-li > div").toggleClass("less");
if ($(".text-size").html() == "Read more...") {
$(".text-size").html("Read less...");
} else {
$(".text-size").html("Read more...");
}
});
});
.less {
word-wrap: break-word;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
}
.more {
white-space: normal;
}
.text-size {
display: block;
text-align: right;
padding-top: 10px;
color: blue !important;
cursor: pointer;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div data-role="page" id="p1">
<div data-role="content">
<ul data-role="listview" data-inset="true">
<li data-role="list-divider">Item Title</li>
<li>
<div class="less">
Need to detect if this text is long enough to show the "Read More" if it is not don't
</div>
<div class="text-size">Read more...</div>
</li>
</ul>
</div>
</div>
Можно ли определить, достаточно ли короткий текст, чтобы поместиться в div, а затем скрыть параметр «Читать дальше»?