Đã có rất nhiều câu trả lời hay ở đây. Để giải trí, tôi đã thực hiện giải pháp này bên dưới, dựa trên các câu trả lời khác và ý tưởng của riêng tôi.
<input class="adjust">
Yếu tố đầu vào được điều chỉnh pixel chính xác và có thể xác định độ lệch bổ sung.
function adjust(elements, offset, min, max) {
offset = offset || 0;
min = min || 0;
max = max || Infinity;
elements.each(function() {
var element = $(this);
var id = btoa(Math.floor(Math.random() * Math.pow(2, 64)));
var tag = $('<span id="' + id + '">' + element.val() + '</span>').css({
'display': 'none',
'font-family': element.css('font-family'),
'font-size': element.css('font-size'),
}).appendTo('body');
function update() {
setTimeout(function() {
tag.html(element.val().replace(/ /g, ' '));
var size = Math.max(min, Math.min(max, tag.width() + offset));
if (size < max)
element.scrollLeft(0);
element.width(size);
}, 0);
};
update();
element.keydown(update);
});
}
adjust($('.adjust'), 10, 100, 500);
Quá trình điều chỉnh sẽ được thực hiện trơn tru với quá trình chuyển đổi CSS.
.adjust {
transition: width .15s;
}
Đây là trò chơi . Tôi hy vọng điều này có thể giúp những người khác đang tìm kiếm một giải pháp sạch.