>웹 프론트엔드 >JS 튜토리얼 >jQuery 플러그인 개발 학습은 실습에서 시작됩니다. 메뉴 플러그인 개발_jquery

jQuery 플러그인 개발 학습은 실습에서 시작됩니다. 메뉴 플러그인 개발_jquery

WBOY
WBOY원래의
2016-05-16 17:54:031046검색

이것은 고급 기술은 아니지만 초보자에게는 여전히 상당히 어렵습니다. 초보자라면 이 글을 통해 뭔가를 배울 수 있었으면 좋겠고, 전문가라면 소중한 의견과 제안을 남겨주세요

1. 어떤 플러그인을 사용해야 하나요?
웹사이트나 WEB 애플리케이션 시스템에서 사용할 수 있고, 유연한 맞춤형 외관을 갖고, 간단하고, 사용하기 쉽고, 확장하기 쉽고, 안정적인 메뉴 플러그인을 구현하고 싶습니다. 웹사이트의 기본 탐색 모음이나 관리 배경에서 사용할 수 있습니다.

2. 원하는 효과는 무엇인가요?
일반적으로 메뉴는 축소된 상태이며, 마우스를 그 안으로 이동하면 해당 하위 메뉴가 표시되는 등 편리하게 html 태그를 사용하여 메뉴 구조를 설정할 수 있습니다. 동적으로 생성하는 배열입니다.

3. 디자인 기능

사진 설명
메뉴 항목의 기본 상태입니다.
하위 메뉴가 있고 그 메뉴에 마우스를 올렸을 때의 상태.
간격(그룹화 효과용)
하위 메뉴가 있으며, 마우스가 움직이지 않은 상태입니다.
세로 레이아웃에는 하위 메뉴가 있고 그 메뉴에 마우스를 넣었을 때의 상태가 있습니다.
포커스가 획득된 상태입니다.
기타 기능
모든 메뉴 상태의 스타일은 CSS를 통해 제어되며 필요에 따라 유연하게 수정할 수 있습니다.
HTML과 자바스크립트를 통해 메뉴를 생성합니다.
메뉴 항목에 대한 클릭 콜백 함수와 점프 주소를 지정합니다(콜백 함수 지정 시 URL 주소는 설정되지 않지만 콜백 함수에 URL 주소가 전달됩니다).
4. 기능을 어떻게 구현하나요?
  1. CSS 스타일을 사용하여 모양을 제어합니다.
  *CSS 이름 충돌을 피하기 위해 플러그인의 네임스페이스를 결정해야 하며, 그 아래의 모든 스타일은 이 네임스페이스 아래에 있게 됩니다.
2. 메뉴 태그 선택
* 일반적으로 메뉴를 구현하는 대부분의 태그는 목록 태그
를 선택하는데 저희도 예외는 아닙니다. .
메뉴 항목:
  • 메뉴 항목 표시 이름

  • 3. 제어 방법 UL 태그를 표시하려면
    * CSS를 사용하여 기호 및 들여쓰기를 제거합니다.
    * CSS를 사용하여 가로로 정렬하는 방법에는 두 가지가 있습니다.
    (1) 가장 일반적으로 사용되는 방법은 플로팅 정렬입니다. : 왼쪽;); 하지만 이 방법의 가장 큰 문제점은 페이지 구조를 파괴한다는 것입니다.
    (2) 인라인(display: inline-block) 방식을 사용하세요. 현재 알려진 문제는 낮은 버전의 브라우저가 이를 잘 지원하지 않을 수 있다는 것입니다. 인터넷에서 이 문제를 논의하는 특별한 기사가 있습니다. 세부.
    *이 방법을 사용했을 때 작은 문제가 있었습니다. 즉, 블록 사이에 약 10px 정도의 간격이 있었습니다. HTML 코드에서 태그 사이의 공백(줄 바꿈)을 삭제한 후 이러한 공백이 사라졌습니다. 이렇게 하면 문제가 해결되지만 코드 구조가 파괴되어 가독성이 떨어지게 됩니다. 그래서 각 블록(
  • 태그)의 왼쪽 여백을 -10px로 설정하고
      의 왼쪽 내부 여백을 10px로 설정하는 또 다른 해결책을 생각해냈습니다!!!
      5 .브라우저 호환성
      IE6 및 IE7에서는 관련 테스트가 수행되지 않았습니다.
      6. 함수 구현 및 호출
      스타일 제어
      코드 복사 코드는 다음과 같습니다.

      코드 보기
      /*이름 충돌을 피하기 위해 이 플러그인의 모든 스타일을 이 클래스에 넣습니다*/
      .ctcx-menu
      {
      글꼴- 크기 :14px;
      }
      .ctcx-menu ul
      {
      list-style-type:none;
      margin:0;
      padding:0;
      }
      /*오프셋 설정*/
      .ctcx-menu ul.offset
      {
      위치:상대적;
      위쪽:-32px;
      왼쪽:100px;
      }
      .ctcx-menu ul li /*메뉴 항목 스타일*/
      {
      width:100px;
      height:30px;
      line-height:30px;
      text-align:center ;
      수직 정렬:상단;
      여백:0;
      패딩:0;
      }
      /*메뉴 항목 스타일*/
      .ctcx-menu a
      {
      디스플레이:블록;
      높이:100%;
      테두리:1px 단색 #999;
      배경색:#FFF;
      텍스트 장식:없음;
      색상:# 000 ;
      }
      .ctcx-menu a:hover
      {
      background-color:#999;
      color:#FFF;
      }
      .ctcx-menu a : 활성{}
      /*가로 메뉴*/
      .ctcx-menu .horizontal
      {
       padding-left:7px;
      }
      .ctcx-menu .horizontal li
      {
      display:inline-block;
      margin-left:-7px;
      }
      .ctcx-menu .horizontal li.item-has-children > a /*하위 메뉴 항목 있음 스타일*/
      {
      }
      .ctcx-menu .horizontal li.spacing /*가로 간격*/
      {
      높이:30px;
      너비:10px; background-color:#000;
      }
      /*세로 메뉴*/
      .ctcx-menu .vertical
      {
      }
      .ctcx-menu .vertical li
      {
      margin-left:0px;
      }
      .ctcx-menu .vertical li.item-has-children > a /*하위 메뉴가 있는 메뉴 항목 스타일*/
      {
      }
      .ctcx-menu .vertical li.spacing /*세로 간격*/
      {
      height:10px;
      width:100px;
      background-color:# 000;
      }

      플러그인 코드

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

      코드 보기
      (함수($) {
          $.fn.menu = 함수(옵션) {
              if (옵션 유형 != '정의되지 않음' && options.constructor === 배열) 옵션 = { 데이터: 옵션 };
              var opts = $.extend({}, $.fn.menu.defaults, options);
              var _tempMenuData = [];
              //返回数据级别
              function getLevel(id) {
                 var _level = 0;
                  var _o = getMenuData(id);
                  while (_o != null) {
                      _level ;
                      _o = getMenuData(_o.pid);
                  }
                  return _level;
              }
              //返回数据对象
              function getMenuData(id) {
                  for (var i = 0; i < ; opts.data.length; i ) {
                     if (opts.data[i].id == id)
                       return opts.data[i];
                }
                null;
      > 🎜>            var _ul = $('
        ');
                    $.each(_li_data, function (i, _d) {
                       var _children = getHtml(_d.id);
                       var _li = $('
      • ').appendTo(_ul);
                        if (_d.n == null || _d.n.length == 0) {
                           _li.addClass('spacing');
                      } else if (typeof _d.fn === 'function') {
                          $('& ㅋ href="javascript:;">').html(_d.n)
                          .click(function () {
                             _d.fn(_d.url);
                            }) .appendTo(_li);
                        } else if (_d.url.length > 0) {
                          $('') .html(_d.n).appendTo(_li);
                        }
                       if (_children != null) {
                          _li.addClass('item-has-children');
                          _children.appendTo(_li);
                            _li.bind({
                               마우스오버: 기능() {
                                  _children.show();
                            },
                            mouseout: 기능() {
            >
                   })
                    if (pid == null && opts.type == 1) {
                      _ul.addClass('horizontal');
                   } else {
                        var _level = getLevel(pid );
                        _level > 0 && _ul.hide();
                       _ul.addClass('vertical');
                       if (_level > opts.type)
                    _ul.addClass('offset');
                    }
        >         _tempMenuData = $.grep(_tempMenuData, 함수 (_d) {
                       if (_d.pid == pid) {
                           _data.push(_d);
                           return true;
                       }
                       false 반환;
                    }, true);
                    return _data;
                }
                return this.each(function () {
                    var me = $(this);
                          만약 ( opts.data != null && opts.data.length > 0) {
                        $.merge(_tempMenuData, opts.data);
                      me.append(getHtml(null));
                    }else {
                                                                                                                 ~ >     _ul.hide() ;                                                    } ); $.fn.menu.defaults = {
        type: 1, //메뉴의 표시 모드(주로 첫 번째 레벨이 수평인지 수직인지를 나타냄, 기본값은 수평 1, 수직 0) )
        /*
        data : 메뉴에 대한 배열 데이터를 동적으로 생성합니다. 이 데이터를 지정하면 메뉴가 이 데이터로 채워집니다. (메뉴의 원래 데이터가 대체됩니다.)
        데이터 형식: [menu ,menu,...]
        메뉴 개체 형식: { id: 1, pid: null, n: '메뉴 이름 1', url: '#', fn: 콜백 함수}
                    */
        );


        JS 코드 호출




        코드 복사


        코드는 다음과 같습니다

        코드 보기
        $(function () {
                            var _menuData = [
                                            > 4', url: '#' },
        { id: 5, pid: null, n: '메뉴 이름 5' ', url: '#' },
                                                               ~                                                    '메뉴 이름 7', URL: ' #' },
                                                                                                        >                            11, pid: 9, n: '메뉴 이름 11', url: '#' },
                                                                      >                                              ~ > ~ 🎜>



        코드 복사


        코드는 다음과 같습니다.

        View Code

                       

                             
        • 一级菜单1

        •                    
        • 一级菜单2

        •                    

        •                         一级菜单3
                                 

                                       
          • 二级菜单1

          •                            
          • 二级菜单2

          •                            
          • 二级菜单3

          •                            

          •                                 二级菜单4
                                           

                                                 
            • 三级菜单1

            •                                    
            • 三级菜单2

            •                                    
            • 三级菜单3

            •                                    
            • 三级菜单4

            •                                    
            • 三级菜单5

            •                                

                                       

          •                            
          • 二级菜单5

          •                        

                             

        •                    
        • 一级菜单4

        •                    
        • 一级菜单5

        •                

                   

                   

                   

                       

                             
        • 一级菜单1

        •                    
        • 一级菜单2

        •                    

        •                         一级菜单3
                                 

                                       
          • 二级菜单1

          •                            
          • 二级菜单2

          •                            
          • 二级菜单3

          •                            

          •                                 二级菜单4
                                           

                                                 
            • 三级菜单1

            •                                    
            • 三级菜单2

            •                                    
            • 三级菜单3

            •                                    
            • 三级菜单4

            •                                    
            • 三级菜单5

            •                                


          •                                                                         
            🎜> > ;/div>



            7. 다운로드

        여기를 클릭
        하여 사용 예시와 모든 파일을 다운로드하세요.
        성명:
        본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.