단축키 사용을 쉽게 도와주는 shortcut.js

· 17년 전 · 2600
 링크1의 글을 올릴 때 찾아보던 기능이었는데 지난 달에 찾았었습니다.
자바스크립트로 웹페이지상에 단축키를 이용해 쉽게 기능을 호출하고 싶을 때 쓰일 수 있ㅤㄱㅖㅆ죠..


vi 단축키를 웹에서도 사용할 정도 하려면 꽤 섬세한 코딩이 되어야겠지만, 한 두개의 특정 단축키만으로도 웹페이지에서 기능을 쉽게 사용하게 할 수 있을겁니다. 그런 자바스크립트 소스입니다..

라이센스: BSD 라이센스.

사이트: 키보드 단축키 핸들링

사용법1: 일반적으로 그냥 단축키를 정의하려면 이렇게 합니다.

shortcut.add("넣고 싶은 단축키 조합",function() {
    alert("Hi there!");   // 해당 단축키를 눌렀을 때 실행할 기능..
});

사용법2: 뒷부분 괄호에 설정값 파라미터들을 더 넣을 수 있습니다. 자세한 파라미터 설정은 사이트를 참조하세요..
shortcut.add("Ctrl+B",function() {
alert("The bookmarks of your browser will show up after this alert...");

},{
'type':'keydown',
'propagate':true,
'target':document
});


HTML문서에 shortcut.js를 링크시키고 위와 같이 shortcut.add... 함수정의를 해주면 단축키가 적용됩니다.

input 태그나 textarea와 같은 내용을 입력하는 곳에선 단축키가 비활성되도록 막는 기능이 추가되었네요..
아래 내용중 'disable_in_input':false 가 그 옵션의 예제입니다. 디폴트는 false이니까 굳이 안적어도 되겠구요..
{
'type':'keydown',
'propagate':false,
'disable_in_input':false,
'target':document,
'keycode':65
}
이런 식의 내용을 세번째 파라미터로 괄호에 넣어서 예제 2에서처럼 정의할 수 있는것이죠..

"넣고 싶은 단축키 조합" <- 첫번째 파라미터로  넣을 수 있는 정의할 단축키 종류는 사이트에 소개되어 있지만, 간략하게 소개하면

조합키[+조합키..]+키

예제:

Ctrl+A

조합키 이름은 아래 이름을 쓸 수 있답니다.

  • Ctrl
  • Alt
  • Shift
  • Meta
아마, Meta 키는 맥OS의 # 비슷하게 생긴 키인가 보네요..

키로 쓸 수 있는 것은
  • All alpha/numeric keys - abc...xyz,01..89
  • Special Characters - Every special character on a standard keyboard can be accessed.
  • Special Keys...
    • Tab
    • Space
    • Return
    • Enter
    • Backspace
    • Scroll_lock
    • Caps_lock
    • Num_lock
    • Pause
    • Insert
    • Home
    • Delete
    • End
    • Page_up
    • Page_down
    • Left
    • Up
    • Right
    • Down
    • F1
    • F2
    • F3
    • F4
    • F5
    • F6
    • F7
    • F8
    • F9
    • F10
    • F11
    • F12
위에 나온 이름을 첫번째 파라미터로 "Ctrl+A" 이런 방식으로 넣으면 해당 키가 눌려질 때 정의된 기능이 실행되는 것이죠..


특정 부위 이하로 단축키가 안먹게 하려면

shortcut.remove()

를 넣으면 되나보군요..

자세한 소개가 못되었지만 사이트를 잘 살펴보시면서
한 번 써먹어 보세요..
[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]

첨부파일

shortcut.js (5.6 KB) 134회 2008-07-18 14:59
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
17년 전 조회 1,541
17년 전 조회 2,196
17년 전 조회 3,280
17년 전 조회 2,220
17년 전 조회 1,610
17년 전 조회 4,318
17년 전 조회 2,109
17년 전 조회 3,548
17년 전 조회 6,118
17년 전 조회 1,573
17년 전 조회 1,732
17년 전 조회 1,320
17년 전 조회 1,422
17년 전 조회 2,955
17년 전 조회 1,980
17년 전 조회 2,677
17년 전 조회 1,376
17년 전 조회 3,259
17년 전 조회 2,242
17년 전 조회 2,679
17년 전 조회 1,494
17년 전 조회 1,841
17년 전 조회 1,227
17년 전 조회 1,283
17년 전 조회 1,865
17년 전 조회 1,301
17년 전 조회 4,380
17년 전 조회 1,594
17년 전 조회 2,086
17년 전 조회 7,173
17년 전 조회 1,459
17년 전 조회 1,978
17년 전 조회 3,203
17년 전 조회 1,300
17년 전 조회 2,063
17년 전 조회 1,222
17년 전 조회 1,923
17년 전 조회 2,242
17년 전 조회 3,049
17년 전 조회 1,325
17년 전 조회 1,404
17년 전 조회 1,635
17년 전 조회 1,311
17년 전 조회 4,440
17년 전 조회 3,980
17년 전 조회 2,866
17년 전 조회 1,674
17년 전 조회 1,408
17년 전 조회 1,670
17년 전 조회 2,601
17년 전 조회 1,816
17년 전 조회 2,099
17년 전 조회 1,379
17년 전 조회 1,117
17년 전 조회 1,197
17년 전 조회 2,996
17년 전 조회 2,542
17년 전 조회 2,122
17년 전 조회 2,124
17년 전 조회 1,871
17년 전 조회 2,320
17년 전 조회 2,087
17년 전 조회 2,056
17년 전 조회 1,941
17년 전 조회 1,278
17년 전 조회 1,894
17년 전 조회 2,300
17년 전 조회 2,386
17년 전 조회 1,710
17년 전 조회 1,580
17년 전 조회 1,437
17년 전 조회 2,654
17년 전 조회 2,744
17년 전 조회 2,135
17년 전 조회 2,491
17년 전 조회 2,798
17년 전 조회 1,392
17년 전 조회 1,251
17년 전 조회 6,401
17년 전 조회 1,249
17년 전 조회 1,707
17년 전 조회 1,842
17년 전 조회 1,167
17년 전 조회 1,264
17년 전 조회 1,957
17년 전 조회 1,594
17년 전 조회 3,698
17년 전 조회 1,282
17년 전 조회 1,980
17년 전 조회 1,238
17년 전 조회 1,465
17년 전 조회 2,431
17년 전 조회 2,089
17년 전 조회 1,101
17년 전 조회 1,116
17년 전 조회 1,174
17년 전 조회 6,117
17년 전 조회 5,917
17년 전 조회 2,100
17년 전 조회 1,097