麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > PHP > 正文

WordPress導航菜單的滾動和淡入淡出效果的實現要點

2024-05-04 23:40:56
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了WordPress導航菜單的滾動和淡入淡出效果的實現要點,講解了根據WordPress默認主題的PHP編寫技巧,需要的朋友可以參考下
 

滾動導航菜單
滾動菜單, 顧名思義是以滾動的方式顯示和隱藏菜單的. 其實跟淡入淡出菜單和滾動菜單的原理是一樣的, 前者是在觸發事件的時候改變菜單的透明度, 而后者則是改變菜單的高度. 那為什么后者的處理難度會比前者高呢? 這正因為菜單高度的處理比透明度有更高的技巧要求. 下面我們就討論一下該如何處理, 并難在什么地方.

初期化處理
為了處理更加靈活, 我們需要為它定義一個作為參數的滑動速度, 也就是每一個單位時間間隔, 菜單高度的改變幅度. 另外, 我們需要將菜單的初始高度定為 0.

// 速度來自參數, 默認沒個時間單位移動 10pxthis.speed = speed || 10;// 設定初始化高度this.util.setStyle(this.body, 'height', '0');

展開和折疊
展開和折疊的方法對應淡入淡出菜單的加強和減小不透明度, 只是處理對象不一樣, 原理是一樣的. 要注意將獲取的高度轉為整型再進行計算.

expand: function() { // 獲取當前高度, 并整型化 var height = parseInt(this.util.getStyle(this.body, 'height')); // 在時間單位內加上速度, 直到高度等于或超過最大高度 height += this.speed; if(height >= this.height) { height = this.height; // 取消循環調用 clearTimeout(this.tid); } // 重新設定菜單高度 this.util.setStyle(this.body, 'height', height + 'px');} /** * 折疊菜單, 直到高度為 1 時隱藏菜單 */collapse:function() { // 獲取當前高度, 并整型化 var height = parseInt(this.util.getStyle(this.body, 'height')); // 在時間單位內減去速度, 直到高度等于或小于 1 height -= this.speed; if(height <= 1) { height = 1; // 隱藏菜單 this.util.setStyle(this.body, 'visibility', 'hidden'); // 取消循環調用 clearTimeout(this.tid); } // 重新設定菜單高度 this.util.setStyle(this.body, 'height', height + 'px');}

激活菜單的瞬間
十分十分十分重要, 滾動菜單中最具技巧, 也最有意思的一部分.
本程序中, 我對獲取高度的方法進行了封裝, 獲取高度其實是返回元素的 offsetHeight. 按我的理解 (不知道是否正確), offsetHeight 會優先去獲取 CSS 樣式中的高度并返回, 當樣式為空時才會去獲取元素的實際高度. 所以有以下代碼:

// 獲得初始高度, 當鼠標在菜單標題上時獲得展開時的初始高度, 當鼠標在菜單體上時取得菜單的實際高度var initHeight = this.util.getStyle(this.body, 'height');// 獲得實際高度, 必須先清空樣式的高度, 否則只會得到樣式中的高度this.util.setStyle(this.body, 'height', '');this.height = this.util.getHeight(this.body);// 重新設定初始高度this.util.setStyle(this.body, 'height', initHeight);

淡出淡入導航菜單
實施操作

前面的分析說得有點啰嗦了, 還是看看代碼吧. :) 為了突出改動的部分, 我在代碼中加入了一些 Log.

初始化
初始不透明度為 0, 而最大不透明度為被設定值或者 1.

// 定義透明度, 默認透明this.opacity = 0;this.maxopacity = opacity || 1;

激活
先進行前期處理, 再對菜單的透明度進行處理.

/** * 激活方法 * 當鼠標移動到菜單標題是激活 */activate: function() { // 獲取當前菜單體的位置 var pos = this.util.cumulativeOffset(this.title); var left = pos[0]; var top = pos[1] + this.util.getHeight(this.title);  // 定義激活時樣式 this.util.setStyle(this.body, 'left', left + 'px'); this.util.setStyle(this.body, 'top', top + 'px'); this.util.setStyle(this.body, 'visibility', 'visible'); this.util.setStyle(this.body, 'opacity', this.opacity); this.util.setStyle(this.body, 'filter', 'alpha(opacity=' + this.opacity * 100 + ')');  if(this.tid) { clearTimeout(this.tid); } // 不斷加強菜單的不透明度 this.tid = setInterval(this.util.bind(this, this.appear), 30);}

加強菜單的不透明度, 直到透明度到達最大不透明度.

/** * 加強不透明度, 直到最大不透明度 */appear: function() { this.opacity += 0.1; if(this.opacity >= this.maxopacity) { this.opacity = this.maxopacity; // 取消循環調用 clearTimeout(this.tid); } // 重新設定透明度 this.util.setStyle(this.body, 'opacity', this.opacity); this.util.setStyle(this.body, 'filter', 'alpha(opacity=' + this.opacity * 100 + ')');}

解除
對菜單的透明度進行處理.

/** * 解除方法 * 當鼠標移動出菜單標題是激活 */deactivate: function(){ if(this.tid) { clearTimeout(this.tid); } // 不斷減弱菜單的不透明度 this.tid = setInterval(this.util.bind(this, this.fade), 30);}

減弱菜單的不透明度, 直到透明度為 0 并隱藏菜單.

/** * 減小不透明度, 直到完全透明隱藏菜單 */fade:function() { this.opacity -= 0.1; if(this.opacity <= 0) { this.opacity = 0; // 隱藏菜單 this.util.setStyle(this.body, 'visibility', 'hidden'); // 取消循環調用 clearTimeout(this.tid); } // 重新設定透明度 this.util.setStyle(this.body, 'opacity', this.opacity); this.util.setStyle(this.body, 'filter', 'alpha(opacity=' + this.opacity * 100 + ')');}


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 深夜免费福利视频 | 国产女同疯狂激烈互摸 | 一级黄色在线观看 | 鲁丝一区二区三区不属 | 麻豆视频在线免费观看 | 精品国产一区二区亚洲人成毛片 | 久久激情小视频 | 亚洲成人免费影视 | 国产一区视频免费观看 | 欧美日韩免费一区 | 中文在线观看免费视频 | 久久久精品视频网站 | 欧美乱码精品一区 | 毛片观看网址 | 视频一区 中文字幕 | 偿还电影免费 | 色综av| 日韩中文字幕三区 | av在线等| 一本色道久久综合狠狠躁篇适合什么人看 | 美国一级毛片片aa久久综合 | fc2成人免费人成在线观看播放 | 久久综合福利 | 激情久久婷婷 | 在线观看免费毛片视频 | 亚洲第一男人天堂 | 99爱视频在线| 精品一区二区三区免费毛片 | 精品在线观看一区二区 | 国产永久免费观看 | 久久福利在线 | 久久精品99国产国产精 | 羞羞羞羞视频 | 午夜爱爱福利 | 成人辣文 | 双性精h调教灌尿打屁股的文案 | 亚洲一区二区三区精品在线观看 | 久久久久免费精品国产小说色大师 | 免费观看黄视频 | 激情视频免费观看 | 日韩字幕在线观看 |