> 웹 프론트엔드 > JS 튜토리얼 > Javascript는 textarea_javascript 스킬에 탭키의 들여쓰기 처리 방식을 구현합니다.

Javascript는 textarea_javascript 스킬에 탭키의 들여쓰기 처리 방식을 구현합니다.

WBOY
풀어 주다: 2016-05-16 15:52:26
원래의
1578명이 탐색했습니다.

이 기사의 예에서는 JavaScript를 사용하여 텍스트 영역에서 탭 키의 들여쓰기 처리를 구현하는 방법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 내용은 다음과 같습니다.

관련 해결 방법을 인터넷에서 검색해 보았는데, 다른 분들은 자바스크립트 두세줄을 사용하여 문제를 해결하셨는데, 모두 사소한 문제가 있었습니다. JQuery를 사용하는 것도 있는데 역시 매우 간단합니다.

본 글의 자바스크립트 코드는 TEXTAREA에 TAB 키를 입력하고 자동으로 들여쓰기하는 기능을 구현한 것입니다. 하지만
에서는 이 코드가 정상적으로 실행되지 않습니다.

코드 복사 코드는 다음과 같습니다.
sel =event.srcElement.document.selection.createRange()

다음 문장에서는 오류가 발생합니다:
ncaugh 예외 TypeError: 정의되지 않은 'selection' 속성을 읽을 수 없습니다

코드는 다음과 같이 IE에서 정상적으로 실행됩니다.

<mce:script type="text/javascript">
<!-- 
function editTab() 
{ 
  var code, sel, tmp, r 
  var tabs="" 
  event.returnValue = false 
  sel =event.srcElement.document.selection.createRange() 
  r = event.srcElement.createTextRange() 
  switch (event.keyCode) 
  { 
    case (8)  : 
      if (!(sel.getClientRects().length > 1)) 
      { 
        event.returnValue = true 
        return 
      } 
      code = sel.text 
      tmp = sel.duplicate() 
      tmp.moveToPoint(r.getBoundingClientRect().left, sel.getClientRects()[0].top) 
      sel.setEndPoint("startToStart", tmp) 
      sel.text = sel.text.replace(/^/t/gm, "") 
      code = code.replace(/^/t/gm, "").replace(//r/n/g, "/r") 
      r.findText(code) 
      r.select() 
      break 
    case (9)  : 
      if (sel.getClientRects().length > 1) 
      { 
        code = sel.text 
        tmp = sel.duplicate() 
        tmp.moveToPoint(r.getBoundingClientRect().left, sel.getClientRects()[0].top) 
        sel.setEndPoint("startToStart", tmp) 
        sel.text = "/t"+sel.text.replace(//r/n/g, "/r/t") 
        code = code.replace(//r/n/g, "/r/t") 
        r.findText(code) 
        r.select() 
      } 
      else 
      { 
        sel.text = "/t" 
        sel.select() 
      } 
      break 
    case (13)  : 
      tmp = sel.duplicate() 
      tmp.moveToPoint(r.getBoundingClientRect().left, sel.getClientRects()[0].top) 
      tmp.setEndPoint("endToEnd", sel) 
      for (var i=0; tmp.text.match(/^[/t]+/g) && i<tmp.text.match(/^[/t]+/g)[0].length; i++)  tabs += "/t" 
      sel.text = "/r/n"+tabs 
      sel.select() 
      break 
    default   : 
      event.returnValue = true 
      break 
  } 
} 
// -->
</mce:script>
로그인 후 복사

사용시:

코드 복사 코드는 다음과 같습니다.

이 기사가 모든 사람의 JavaScript 프로그래밍 설계에 도움이 되기를 바랍니다.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿