摘要:使背景圖始終位于屏幕中心插件的開發方式類級別組件開發即給命名空間添加新的全局函數,也稱靜態方法例如對象級別組件開發即掛在原型下的方法,這樣通過選擇器獲取的對象實例也能共享該方法,也稱動態方法這里例如等需要創建實例來調用頁面切換
使背景圖始終位于屏幕中心
#section1, #section2, #section3, #section4{ background-color: #000; background-size: cover; background-position: 50% 50%; text-align: center; color: white; }
jquery插件的開發方式
類級別組件開發
即給jquery命名空間添加新的全局函數,也稱靜態方法
jQuery.myPlugin = function () { //do something }
例如 $.Ajax()、$.extend()
對象級別組件開發
即 掛在jQuery原型下的方法,這樣通過選擇器獲取的jquery對象實例也能共享該方法,也稱動態方法
$.fn.myPlugin = function () { //do something }; //這里$.fn === $.prototype
例如: addClass() 、 attr() 等,需要創建實例來調用
頁面切換 switchPage
Create Beautiful Fullscreen Scrolling Websites
Example
HTML markup example to define 4 sections
Example
The plug-in configuration parameters
THE END
Everything will be okay in the end. If it"s not okay, it"s not the end.
(function($){ "use strict"; /*說明:獲取瀏覽器前綴*/ /*實現:判斷某個元素的css樣式中是否存在transition屬性*/ /*參數:dom元素*/ /*返回值:boolean,有則返回瀏覽器樣式前綴,否則返回false*/ var _prefix = (function(temp){ var aPrefix = ["webkit", "Moz", "o", "ms"], props = ""; for(var i in aPrefix){ props = aPrefix[i] + "Transition"; if(temp.style[ props ] !== undefined){ return "-"+aPrefix[i].toLowerCase()+"-"; } } return false; })(document.createElement(PageSwitch)); var PageSwitch = (function(){ function PageSwitch(element, options){ this.settings = $.extend(true, $.fn.PageSwitch.defaults, options||{}); this.element = element; this.init(); } PageSwitch.prototype = { /*說明:初始化插件*/ /*實現:初始化dom結構,布局,分頁及綁定事件*/ init : function(){ var me = this; me.selectors = me.settings.selectors; me.sections = me.element.find(me.selectors.sections); me.section = me.sections.find(me.selectors.section); me.direction = me.settings.direction == "vertical" ? true : false; me.pagesCount = me.pagesCount(); me.index = (me.settings.index >= 0 && me.settings.index < me.pagesCount) ? me.settings.index : 0; me.canscroll = true; if(!me.direction || me.index){ me._initLayout(); } if(me.settings.pagination){ me._initPaging(); } me._initEvent(); }, /*說明:獲取滑動頁面數量*/ pagesCount : function(){ return this.section.length; }, /*說明:獲取滑動的寬度(橫屏滑動)或高度(豎屏滑動)*/ switchLength : function(){ return this.direction == 1 ? this.element.height() : this.element.width(); }, /*說明:向前滑動即上一頁*/ prve : function(){ var me = this; if(me.index > 0){ me.index --; }else if(me.settings.loop){ me.index = me.pagesCount - 1; } me._scrollPage(); }, /*說明:向后滑動即下一頁*/ next : function(){ var me = this; if(me.index < me.pagesCount){ me.index ++; }else if(me.settings.loop){ me.index = 0; } me._scrollPage(); }, /*說明:主要針對橫屏情況進行頁面布局*/ _initLayout : function(){ var me = this; if(!me.direction){ var width = (me.pagesCount * 100) + "%", cellWidth = (100 / me.pagesCount).toFixed(2) + "%"; me.sections.width(width); me.section.width(cellWidth).css("float", "left"); } if(me.index){ me._scrollPage(true); } }, /*說明:主要針對橫屏情況進行頁面布局*/ _initPaging : function(){ var me = this, pagesClass = me.selectors.page.substring(1); me.activeClass = me.selectors.active.substring(1); var pageHtml = "
參考:
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/82732.html
摘要:為了給用戶帶來多媒體方面的體驗福利,一刻也不能停,現在要提升主要視頻應用全屏播放的觀看體驗。 為了給用戶帶來多媒體方面的體驗福利,一刻也不能停,現在要提升主要視頻應用全屏播放的觀看體驗。 提升主要視頻應用全屏播放的觀看體驗老板撂下一句話后拂袖而去,剩下的自己體會。經過人工智能的大腦快速處理,提取了幾個比較關鍵的技術點。 1.視頻應用,如何判斷到視頻應用在工作? 2.全屏播放,如何判斷視...
摘要:由此,我們可以完全屏蔽的默認滾動觸發,改用方法控制全屏滾動,解除了全屏滾動與鼠標滾輪事件的強耦合。此外,通過定時器延時秒設置的值,將用戶的鼠標滾輪操作強制分為兩步,最終實現了目的。 需求分析 剛進公司產品提出一個需求:在全屏頁面中滾動鼠標滾輪更新文本,回滾再恢復原文本,同時不影響全屏頁面的正常切換: 初始狀態 showImg(https://segmentfault.com/img/b...
摘要:回顧算了不回顧了直接搞起,打開中寫的播放視頻播放按鈕隱藏視頻開始播放當點擊播放按鈕的時候,播放按鈕將會隱藏,播放視頻,這個不難,在中我們就已經實現。 回顧 算了不回顧了 showImg(https://segmentfault.com/img/bVBQyx?w=77&h=76);直接搞起,打開JS1中寫的bvd.js 播放視頻 播放按鈕隱藏 視頻開始播放 當點擊播放按鈕的時候,播...
閱讀 3286·2021-11-18 10:02
閱讀 3450·2021-10-11 10:58
閱讀 3382·2021-09-24 09:47
閱讀 1129·2021-09-22 15:21
閱讀 3952·2021-09-10 11:10
閱讀 3283·2021-09-03 10:28
閱讀 1753·2019-08-30 15:45
閱讀 2147·2019-08-30 14:22