>  기사  >  웹 프론트엔드  >  javascript를 사용하여 textarea_javascript 기술에서 커서 위치를 가져옵니다.

javascript를 사용하여 textarea_javascript 기술에서 커서 위치를 가져옵니다.

WBOY
WBOY원래의
2016-05-16 19:04:531173검색

JavaScript 및 웹 페이지 편집기를 작성하는 사람들에게 텍스트 영역에서 커서 위치를 얻는 것은 매우 중요한 문제이며 많은 사람들이 이 영역에서 종종 헤매고 좋은 방법을 찾지 못합니다. 어제 인터넷에서 자바스크립트 코드 조각을 발견했습니다. 너무 흥미롭고 변경될까봐 원본 버전을 여기에 넣고 싶지 않았기 때문에 여기에 원본 버전을 넣겠습니다.

var start=0;
var end=0;
function add(){
var textBox = document.getElementById("ta"); ;
var post = textBox.value.substr(end);
textBox.value = pre document.getElementById("inputtext").value post
}
function savePos(textBox) 🎜> //Firefox(1.5)라면 방법은 매우 간단합니다
if(typeof(textBox.selectionStart) == "number"){
start = textBox.selectionStart
           end = textBox; .selectionEnd;                                                🎜> var range = document.selection.createRange();
if(range.parentElement().id == textBox.id){
var range = document.select 이온.createRange(); / 전체 텍스트 영역의 선택 항목 생성
var range_all = document.body.createTextRange();
range_all.moveToElementText(textBox);
range_all .compareEndPoints()는 두 끝점을 비교합니다. 범위보다 왼쪽, //0보다 작은 값을 반환한 다음, range_all은 두 범위의 시작이 동일해질 때까지 약간 오른쪽으로 이동합니다.
               //range_all의 시작을 범위의 시작으로 이동하여 선택 시작점을 계산합니다.
               for(start=0; range_all.compareEndPoints("StartToStart", range)                    range_all.moveStart(' 문자', 1);
               // 텍스트 영역 시작부터 선택 시작까지 줄 바꿈 수를 가져오고 시작에 추가합니다.
              // 计算一下
              for (var i = 0; i                  if (textBox.value.charAt(i) == 'n')                      시작 ;
               }
                // 전체 텍스트 영역의 선택 항목을 생성합니다
                var range_all = document.body.createTextRange();
                 range_all.moveToElementText(textBox);
               //range_all의 시작을 범위의 끝으로 이동하여 선택 끝점을 계산합니다.
              (end = 0; range_all.compareEndPoints('StartToEnd', range)                     range_all.moveStart(' 문자', 1);                    // 텍스트 영역 시작부터 선택 항목 끝까지 줄바꿈 수를 가져와서 끝에 추가하세요.
                  for(var i = 0; i                         if (textBox.value.charAt( i) == 'n')
                            끝  ;                     }
               }
            }
        document.getElementById("start").value = start;
        document.getElementById("end").value = end;
    }
페이지에서 js 코드를 호출하는 방법은 다음과 같습니다.



    
        
        
    
    
        
    
    
        
        
    
start:  end: 

            
        

 시작:  끝:



이 코드의 원본 텍스트는 http://blog.csdn.net/liujin4049/archive/2006/09/19/1244065.aspx입니다. 감사합니다. 너! 이 js 코드는 IE와 Firefox를 모두 지원하는데, 이 사람이 js 실력이 뛰어나다는 걸 보여주는군요. 하하. 그런데 Firefox의 현재 시장 점유율은 17%에 이르렀고, 곧 IE8이 나온다고 들었습니다. 브라우저 간에 또 한 번의 사투가 벌어질 것인데, 이런 싸움이 브라우저를 파싱하게 만들 수 있습니다. 표준은 점점 더 표준화될 것이고, 코드 작성이 점점 더 쉬워질 것이라는 점은 정말 기쁠 것입니다.
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.