यहां पहले से ही बहुत अच्छे जवाब हैं। मज़े के लिए, मैंने नीचे दिए गए इस समाधान को लागू किया, अन्य उत्तरों और मेरे अपने विचारों के आधार पर।
<input class="adjust">
इनपुट तत्व समायोजित पिक्सेल सटीक है और एक अतिरिक्त ऑफसेट को परिभाषित किया जा सकता है।
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);
समायोजन एक सीएसएस संक्रमण के साथ सुचारू हो जाता है।
.adjust {
transition: width .15s;
}
यहाँ है बेला । मुझे आशा है कि यह दूसरों को एक स्वच्छ समाधान की तलाश में मदद कर सकता है।