반응형
    
    
    
  업무를 진행하면서 jquery-ui를 이용해서 툴팁을 만들때 툴팁위에 마우스를 올렸을 때 툴팁이 유지되도록 하는 기능을 만들어야 했다.
구글링을 통해서 방법을 찾았고 그 방법을 공유해보자.
먼저 기본적인 툴팁이 적용된 input box예제를 살펴보자.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | <!doctype html> <html lang = "en">    <head>       <meta charset = "utf-8">       <title>jQuery UI Tooltip functionality</title>       <link href = "https://code.jquery.com/ui/1.10.4/themes/ui-lightness/jquery-ui.css"          rel = "stylesheet">       <script src = "https://code.jquery.com/jquery-1.10.2.js"></script>       <script src = "https://code.jquery.com/ui/1.10.4/jquery-ui.js"></script>       <!-- CSS -->       <style>          body {             margin-top: 100px;          }          .ui-tooltip-content::after, .ui-tooltip-content::before {             content: "";             position: absolute;             border-style: solid;             display: block;             left: 90px;          }          .ui-tooltip-content::before {             bottom: -10px;             border-color: #AAA transparent;             border-width: 10px 10px 0;          }          .ui-tooltip-content::after {             bottom: -7px;             border-color: white transparent;             border-width: 10px 10px 0;          }       </style>       <!-- Javascript -->       <script>          $(function() {             $( "#tooltip-7" ).tooltip({                position: {                   my: "center bottom",                   at: "center top-10",                   collision: "none"                }             });          });       </script>    </head>    <body>       <!-- HTML -->       <label for = "name">Enter Date of Birth:</label>       <input id = "tooltip-7" title = "Please use MM.DD.YY format.">    </body> </html> | cs | 
단순하게 툴팁이 출력되고 마우스를 가져다 되면 사라져버린다.
툴팁에 마우스를 가져다 되었을 때 툴팁을 유지하기 위해서는 툴팁이 닫히려고 하는 이벤트에 ui hover 이벤트를 달아주면된다. 예제 코드는 다음과 같다.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | $(function() {             $( "#tooltip-7" ).tooltip({                position: {                   my: "center bottom",                   at: "center top-10",                   collision: "none"                },                 close: function( event, ui ) {                   ui.tooltip.hover(                       function () {                           $(this).stop(true).fadeTo(400, 1);                           //.fadeIn("slow"); // doesn't work because of stop()                       },                       function () {                           $(this).fadeOut("400", function(){ $(this).remove(); })                       }                   );                 }             });          }); | cs | 
결과를 확인해보면 마우스를 위에 가져다 놓아도 사라지지 않는 것을 확인할 수 있다.
반응형
    
    
    
  'web > jquery' 카테고리의 다른 글
| Context Menu를 내 마음대로 변경하는 Jquery-ContextMenu.js 사용방법 소개 (0) | 2018.05.27 | 
|---|---|
| dom element를 자유롭게 움직이고 수정할 수있게 하는 gridstack.js 소개 (0) | 2018.05.27 |