亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

html5寫一個BUI折疊菜單插件的實現方法

2024-09-05 07:23:01
字體:
來源:轉載
供稿:網友

寫一個BUI折疊菜單插件效果預覽

控件分析控件結構

一個點擊顯示隱藏的效果, 并且點擊的時候, 會先把展開進行隱藏, 再展開自己的. 從界面上我們來看看結構的設計.
<!-- 一般控件最外層就是控件的容器名 --><div class="bui-foldmenu">    <div class="bui-foldmenu-item">菜單</div>    <div class="bui-foldmenu-content">內容</div>    <div class="bui-foldmenu-item">菜單2</div>    <div class="bui-foldmenu-content">內容2</div></div>
這里我們采用的是并列同級的方式, 那結構寫起來有點麻煩, 其實這個結構跟 dl,dt,dd 是一致的, 那我們完全可以優化成以下結構.
<!-- 一般控件最外層就是控件的容器名 --><dl class="bui-foldmenu">    <dt>菜單</dt>    <dd>內容</dd>    <dt>菜單2</dt>    <dd>內容2</dd></dl>
bui的設計是基于按鈕的原型撐開容器的方式, 這樣可以保持每個容器都是一致的標準高度, 所以我們再對結構進行優化.
<!-- 一般控件最外層就是控件的容器名 --><dl class="bui-foldmenu">    <dt class="bui-btn">菜單</dt>    <dd>內容</dd>    <dt class="bui-btn">菜單2</dt>    <dd>內容2</dd></dl>
像剛剛效果圖,菜單的點擊還會有圖標的切換, 再結合布局來得到以下結構, 一切皆布局, 一切皆容器.
<!-- 一般控件最外層就是控件的容器名 --><dl class="bui-foldmenu">    <dt class="bui-btn bui-box"><div class="span1">菜單</div><i class="icon-foldmenu"></i></dt>    <dd>內容</dd>    <dt class="bui-btn bui-box"><div class="span1">菜單2</div><i class="icon-foldmenu"></i></dt>    <dd>內容2</dd></dl>

控件樣式

一般作為插件的獨立樣式引入, bui-foldmenu.css文件

 

.bui-foldmenu {}.bui-foldmenu>dt,.bui-foldmenu>[class*=bui-btn] {    border: 0;    border-bottom: 1px solid #eee;}/*  默認隱藏內容 */.bui-foldmenu>dd {    display: none;    border: 0;    overflow-y: auto;    border-bottom: 1px solid #eee;    background: #fff;}/*  圖標 */.bui-foldmenu .icon-foldmenu {    -webkit-transition: -webkit-transform 0.3s ease-in-out 0s;    transition: transform 0.3s ease-in-out 0s;}.bui-foldmenu .icon-foldmenu:before {    content: "/e649";}/* 激活的時候顯示block */.bui-foldmenu>.active+dd {    display: block;}/* 激活的二級菜單的時候,把箭頭翻轉 */.bui-foldmenu>.active .icon-foldmenu {    -webkit-transform: rotate(-180deg);    transform: rotate(-180deg);}
樣式里面就默認隱藏內容標簽(dt相鄰的dd),由控件初始化, 其它都是一些修飾, 設置激活狀態的時候,箭頭翻轉.

控件腳本

1.5.4 新增 bui.extend 方法,可以用來擴展插件, 并且保持跟 bui原本的使用方式一致.

bui.extend 控件參數是一個對象, 其中包含以下參數

name string 控件名稱config object 控件默認參數callback function 控件的邏輯最簡單的版本

// 最簡單的版本bui.extend({    name: "foldmenu",    config: {        id: ""    },    callback: function(opt) {        // that 指向插件的拋出的公共方法, option widget 等        let that = this;        // this.config 為已經跟初始化參數合并以后的結果;        let param = this.config;        // 緩存選擇器        let $id = null;        // 要拋給開發者的方法        that.init = function(option) {            // 對直接調用init方法的參數進行合并            param = $.extend(true, {}, param, option);            // 單頁多頁選擇器,如果是單頁,這個插件只能在模塊里面用, 不能在bui.ready            $id = bui.$(param.id);                // 綁定事件,點擊的時候增加激活樣式            $id.children("dt").click(function(e) {                var hasActive = $(this).hasClass("active");                if (hasActive) {                    $(this).removeClass("active");                } else {                    // 加上樣式以后會自動對箭頭及下一層級展示處理;                    $(this).addClass("active");                }            })            return that;        }        // 如果有依賴bui控件,應該在這里寫,這樣方便外部調用        // that.widgets.loading = ui.loading({        //     appendTo: opt.id        // });        // 如果需要銷毀的生命周期,則在這里加上.        // that.beforeDestroy = function() {        //        //     return that;        // }        // 必須傳id        if (!param.id) {            // 拋出錯誤            bui.showLog("必須傳id參數.")            return that;        }        // 默認先初始化一次        return this.init(opt);    }});

控件使用

<dl id="folder" class="bui-foldmenu">    <dt class="bui-btn">菜單</dt>    <dd>內容</dd>    <dt class="bui-btn">菜單2</dt>    <dd>內容2</dd></dl>
  // 初始化  var uiFloder = bui.foldmenu({id:"#folder"})  // uiFloder.config 可以拿到一些實例的參數

插件預覽

在線預覽bui.folder插件

完善插件

用閉包防止全局污染

放在一個閉包里,這樣可以防止控件受到污染, window.libs 指的是 zepto 或者 jquery, 當你去掉引入 zepto.js 的時候, 引入 jquery.js 就可以完美切換成jquery版本. (jquery版本建議在: 1.9.x - 1.11.x)
;(function(ui, $) {    "use strict";})(window.bui || {}, window.libs);

加上注釋

/* @namespace bui  *  @class foldmenu  *  @constructor  *  @param {object} option  *  @param {string} option.id [控件id]  *  @param {string} [option.handle] [點擊的區域]  *  @param {number} [option.height] [父層高度,0則自適應]  *  @param {string} [option.target] [要顯示隱藏的目標]  *  @param {number} [option.targetHeight] [目標自適應高度還是限制高度]  *  @param {boolean} [option.single] [ false(顯示多個) || true(一次只折疊一個) ]  *  @param {function} [option.onInited] [ 1.5.1新增 初始化以后觸發 ]  *  @param {function} [option.callback] [ 點擊按鈕的回調 ]  *  @example  *  */

完整版

;(function(ui, $) {    "use strict";    /* @namespace bui      *  @class foldmenu      *  @constructor      *  @param {object} option      *  @param {string} option.id [控件id]      *  @param {string} [option.handle] [點擊的區域]      *  @param {number} [option.height] [父層高度,0則自適應]      *  @param {string} [option.target] [要顯示隱藏的目標]      *  @param {number} [option.targetHeight] [目標自適應高度還是限制高度]      *  @param {boolean} [option.single] [ false(顯示多個) || true(一次只折疊一個) ]      *  @param {function} [option.onInited] [ 1.5.1新增 初始化以后觸發 ]      *  @param {function} [option.callback] [ 點擊按鈕的回調 ]      *  @example      *      */      ui.extend({          name: "foldmenu",          config: {              id: ""          },          callback: function(opt) {              // that 指向插件的拋出的公共方法, option widget 等              let that = this;              // this.config 為已經跟初始化參數合并以后的結果;              let param = this.config;              // 緩存選擇器              let $id = null;              // 要拋給開發者的方法              that.init = function(option) {                  // 對直接調用init方法的參數進行合并                  param = $.extend(true, {}, param, option);                  // 單頁多頁選擇器,如果是單頁,這個插件只能在模塊里面用, 不能在bui.ready                  $id = ui.$(param.id);                      // 綁定事件,點擊的時候增加激活樣式                  $id.children("dt").click(function(e) {                      var hasActive = $(this).hasClass("active");                      if (hasActive) {                          $(this).removeClass("active");                      } else {                          // 加上樣式以后會自動對箭頭及下一層級展示處理;                          $(this).addClass("active");                      }                  })                  return that;              }              // 如果有依賴bui控件,應該在這里寫,這樣方便外部調用              // that.widgets.loading = ui.loading({              //     appendTo: opt.id              // });              // 如果需要銷毀的生命周期,則在這里加上.              // that.beforeDestroy = function() {              //              //     return that;              // }              // 必須傳id              if (!param.id) {                  // 拋出錯誤                  ui.showLog("必須傳id參數.")                  return that;              }              // 默認先初始化一次              return this.init(opt);          }      });})(window.bui || {}, window.libs);

結語

上面我們示例了一個最簡單的插件的開發及使用, 但插件的適應性還不夠, 還需要考慮各種擴展性,復雜的場景如何去適應, 比方內容是需要固定高度,選擇器換成其它,只展示一個,等各種需求都不能滿足, 我們需要考慮更多的場景, 抽取更多的變量作為可配置.

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久aaaa九色| 亚洲欧美精品一区二区| 亚洲欧美精品伊人久久| 91久久久久久久一区二区| 欧美在线视频一区| 欧美资源在线观看| 在线视频日韩精品| 国产精品旅馆在线| 欧美xxxx做受欧美| 久久电影一区二区| 中文字幕在线视频日韩| 日韩美女视频免费在线观看| 日韩欧美国产中文字幕| 亚洲性av在线| 综合网日日天干夜夜久久| 亚洲直播在线一区| 亚洲高清久久网| 亚洲国产精品99久久| 亚洲一区av在线播放| 日韩av手机在线| 久久精品福利视频| 国内精品视频在线| 国产亚洲欧美另类中文| 78色国产精品| 久久久久免费视频| 中文字幕亚洲情99在线| 欧美性视频精品| 孩xxxx性bbbb欧美| 26uuu久久噜噜噜噜| 91精品国产自产在线老师啪| 久久久精品国产网站| 欧美亚洲成人免费| 亚洲精品网站在线播放gif| 中文字幕日韩高清| 国产精品电影久久久久电影网| 一本色道久久综合狠狠躁篇的优点| 57pao精品| 91精品国产一区| 中文字幕亚洲欧美日韩高清| 国产美女被下药99| 午夜剧场成人观在线视频免费观看| 欧美日韩午夜视频在线观看| 这里只有精品视频| 国产精品久久久久久亚洲影视| 精品人伦一区二区三区蜜桃免费| 亚洲va男人天堂| 精品日本美女福利在线观看| 51色欧美片视频在线观看| 亚洲国模精品私拍| 一个人www欧美| 国产精品久久99久久| 国产精品成人播放| 日本成人免费在线| 成人午夜激情网| 精品国产一区二区三区在线观看| www.欧美免费| 国内免费久久久久久久久久久| 国产成人拍精品视频午夜网站| 日韩美女主播视频| 国模吧一区二区| 日韩高清电影好看的电视剧电影| 九九热99久久久国产盗摄| 欧美性极品xxxx做受| 日韩av在线免费| 综合av色偷偷网| 欧美黑人巨大精品一区二区| 亚洲日本中文字幕免费在线不卡| 日韩最新在线视频| 国产成人a亚洲精品| 亚洲视频一区二区三区| 日韩av在线一区| 亚洲电影第1页| 欧美精品激情blacked18| 欧美色另类天堂2015| 欧美中文字幕第一页| 亚洲精品成人网| 全亚洲最色的网站在线观看| 6080yy精品一区二区三区| 在线精品视频视频中文字幕| 久久国产精品久久国产精品| 亚洲人在线视频| 久久福利视频网| 亚洲91av视频| 精品高清一区二区三区| 中文字幕久久精品| 亚洲国产成人精品电影| 91禁外国网站| 亚洲国产91精品在线观看| 日韩欧美在线播放| 亚洲色无码播放| 热久久这里只有| 亚洲伊人一本大道中文字幕| 中文字幕亚洲一区二区三区五十路| 国产日韩欧美日韩| 欧美成人免费全部观看天天性色| 欧美中文在线字幕| 久久手机免费视频| 欧美精品情趣视频| 亚洲丁香久久久| 久久综合色影院| 欧美激情一区二区三区高清视频| 国产精品情侣自拍| 欧美日韩国产丝袜另类| 日本电影亚洲天堂| 96国产粉嫩美女| 中文字幕日韩精品在线观看| 欧美片一区二区三区| 国产精品欧美在线| 岛国av在线不卡| 成人av番号网| 国产精品美女主播在线观看纯欲| 超碰91人人草人人干| 欧美亚洲视频在线观看| 91高清视频在线免费观看| 精品久久久久久久久久国产| 中文字幕精品影院| 国产欧美日韩专区发布| 欧美一区二区三区免费观看| 亚洲精品97久久| 精品精品国产国产自在线| 97视频在线观看亚洲| 亚洲精品一区二三区不卡| 亚洲女人天堂网| 66m—66摸成人免费视频| 国产69精品久久久久99| 国产日韩欧美另类| 亚洲大胆人体av| 91欧美精品成人综合在线观看| 亚洲va欧美va在线观看| 国产精品69久久久久| 亚洲国产欧美一区二区三区同亚洲| 国产欧美一区二区三区在线看| 精品视频中文字幕| 亚洲少妇中文在线| 在线成人激情黄色| 精品国产欧美成人夜夜嗨| 国产精品99蜜臀久久不卡二区| 日韩国产高清污视频在线观看| 成人黄色av免费在线观看| 亚洲国产成人精品久久久国产成人一区| 久久久亚洲影院你懂的| 欧美亚洲另类视频| 欧美精品18videos性欧美| 国产拍精品一二三| 一区二区三区回区在观看免费视频| 日韩精品免费在线视频| 久久精品视频在线观看| 久久久久久高潮国产精品视| 欧美日韩亚洲国产一区| 亚洲网在线观看| 亚洲女在线观看| 国产欧美va欧美va香蕉在| 色777狠狠综合秋免鲁丝| 九九久久综合网站| 国产91露脸中文字幕在线| 日韩国产欧美精品一区二区三区| 成人伊人精品色xxxx视频| 国产成人精品一区二区三区| 日韩精品亚洲视频| 97视频com| 国产日韩欧美在线看| 正在播放欧美视频| 久久久精品999| 久久久久久伊人|