আপডেট হয়েছে 5 সেপ্টেম্বর 2010
প্রত্যেকে যেমন এই সমস্যার জন্য এখানে নির্দেশ পেয়েছে বলে মনে হচ্ছে, আমি আমার উত্তরটি একইরকম প্রশ্নের সাথে যুক্ত করছি, যার উত্তরটির মতো একই কোড রয়েছে তবে আগ্রহীদের জন্য পুরো পটভূমি সহ:
আইই এর ডকুমেন্ট.স্লেশন.ক্রিয়েটরেঞ্জের মধ্যে ফাঁকা লাইনগুলি শীর্ষস্থানীয় বা অনুসরণ করার অন্তর্ভুক্ত নয়
আইলিতে লম্বালম্বি বিরতি রোধের জন্য অ্যাকাউন্টিং করা জটিল, এবং আমি এই প্রশ্নের অন্য কোনও উত্তর সহ সঠিকভাবে এটির কোনও সমাধান দেখিনি। তবে, নিম্নলিখিত ফাংশনটি ব্যবহার করে এটি সম্ভব, যা আপনাকে নির্বাচনের শুরু এবং শেষটি কোনও <textarea>
পাঠ্যের মধ্যে বাছাইয়ের (যা একটি কেরেটের ক্ষেত্রে একই রকম) ফিরিয়ে দেবে <input>
।
নোট করুন যে টেক্সারিয়ায় আইইতে সঠিকভাবে কাজ করার জন্য এই ফাংশনটির জন্য ফোকাস থাকতে হবে। যদি সন্দেহ হয় তবে focus()
প্রথমে টেক্সারিয়ার পদ্ধতিটি কল করুন ।
function getInputSelection(el) {
var start = 0, end = 0, normalizedValue, range,
textInputRange, len, endRange;
if (typeof el.selectionStart == "number" && typeof el.selectionEnd == "number") {
start = el.selectionStart;
end = el.selectionEnd;
} else {
range = document.selection.createRange();
if (range && range.parentElement() == el) {
len = el.value.length;
normalizedValue = el.value.replace(/\r\n/g, "\n");
// Create a working TextRange that lives only in the input
textInputRange = el.createTextRange();
textInputRange.moveToBookmark(range.getBookmark());
// Check if the start and end of the selection are at the very end
// of the input, since moveStart/moveEnd doesn't return what we want
// in those cases
endRange = el.createTextRange();
endRange.collapse(false);
if (textInputRange.compareEndPoints("StartToEnd", endRange) > -1) {
start = end = len;
} else {
start = -textInputRange.moveStart("character", -len);
start += normalizedValue.slice(0, start).split("\n").length - 1;
if (textInputRange.compareEndPoints("EndToEnd", endRange) > -1) {
end = len;
} else {
end = -textInputRange.moveEnd("character", -len);
end += normalizedValue.slice(0, end).split("\n").length - 1;
}
}
}
}
return {
start: start,
end: end
};
}