摘要:某天機(jī)緣巧合之下看到一文章然后被深深的迷上了鏈接在此用又學(xué)了一招,活變美女但是已經(jīng)了然后花幾天時(shí)間去封裝一下水平有限所以標(biāo)題注明簡(jiǎn)陋版首先我們用的女神圖片一基本框架搭建先來看看基本框架構(gòu)建長(zhǎng)這樣子我家女神點(diǎn)擊看美女現(xiàn)在來逐步分析一
某天,機(jī)緣巧合之下看到一文章,然后被深深的迷上了,鏈接在此brucelyy:用又學(xué)了一招,活變美女(但是已經(jīng)404了)
然后花幾天時(shí)間去封裝一下,水平有限,所以標(biāo)題注明簡(jiǎn)!陋!!版!!!
首先我們用的女神圖片
先來看看基本框架構(gòu)建長(zhǎng)這樣子
我家女神
現(xiàn)在來逐步分析一下主要代碼作用:
html {overflow: hidden;} //隱藏滾動(dòng)條引起的抖動(dòng)
其中能實(shí)現(xiàn)的關(guān)鍵布局在于下面代碼:
#wrapper div { background-image: url("http://b-ssl.duitang.com/uploads/item/201801/14/20180114134621_auNRE.jpeg"); background-repeat: no-repeat; background-size: 40rem auto; position: absolute; width: 40rem; height: 40rem; }
如果不使用絕對(duì)定位接下來的碎片化無法完成的,
由此也可以發(fā)現(xiàn)簡(jiǎn)陋版目前問題一:必須使用背景圖實(shí)現(xiàn);
背景圖引起的問題二:需要設(shè)置高寬尺寸
其他就沒什么好說了,目前html+部分就出來了
其實(shí)原理說起來也不復(fù)雜,就是生成多個(gè)小元素分別定位截圖,然后通過伸縮,旋轉(zhuǎn),變形,透明等效果用時(shí)間差展現(xiàn).這里直接使用3屬性,控制一個(gè)類匹配控制效果
生成時(shí)間差的:
// 生成隨機(jī)時(shí)間差 function Random(start, end) { return Math.random() * (end - start) + start; }
實(shí)現(xiàn)效果是通過拆分多個(gè)小碎片然后記錄當(dāng)前位置定位圖片位置,做成類似雪碧圖的效果
// 拆分多個(gè)小碎片然后記錄當(dāng)前位置定位圖片位置,做成類似雪碧圖的效果 for (var i = 0; i < r; i++) { for (var j = 0; j < c; j++) { var _div = document.createElement("div"); var _left = j * w, _top = i * h; _div.style.Text = "width:" + w + "px;height:" + h + "px;left:" + _left + "px;top:" + _top + "px; opacity:0;background-position:" + (-_left) + "px " + (-_top) + "px"; _div.style.transition = "all " + Random(1, 1.8) + "s ease"; _div.style.transform = "perspective(800px) translate3d(" + Random(-200, 200) + "px, " + Random(-200, 200) + "px,300px) rotate(" + Random(-90, 90) + "deg) scale(" + Random(0, 2) + ")" box.appendChild(_div); } }
因?yàn)檫@樣子分別插入太耗性能了,我是通過字符創(chuàng)批量插入
由此也可以發(fā)現(xiàn)簡(jiǎn)陋版目前問題三:性能損耗大,暫時(shí)思路可以考慮canvas,不過我研究不多,就先用字符串解決先;
觸發(fā)的關(guān)鍵樣式:
#div.set div { opacity: 1 !important; transform: perspective(800px) translate3d(0px, 0px, 0px) rotate(0deg) scale(1) !important; -moz-transform: perspective(800px) translate3d(0px, 0px, 0px) rotate(0deg) scale(1) !important; -webkit-transform: perspective(800px) translate3d(0px, 0px, 0px) rotate(0deg) scale(1) !important; }
這個(gè)好在是通過樣式控制而不是js觸發(fā),省事好多
三,終于開始封裝了這里我是基于提升個(gè)人寫作水平跟對(duì)新手友好態(tài)度寫得比較詳細(xì)啰嗦,老手直接跳到最下看代碼就行了.
現(xiàn)在大家應(yīng)該都明白原理了,還是為了省事,我就直接用jQuery封裝了,常規(guī)步驟先寫個(gè)外層:
$(function($) { //默認(rèn)配置 var defaults = { }; }(jQuery));
然后前面的時(shí)間差函數(shù)可以直接在jQuery內(nèi)部作為全局函數(shù)的插件附加到內(nèi)核上去的,而常規(guī)的配置可以有:觸發(fā)元素,分列數(shù)量,動(dòng)畫時(shí)間,延遲時(shí)間和控制動(dòng)畫的類名;即
$(function ($) { //默認(rèn)配置 var defaults = { className: "explode",//控制類名 button: null, //觸發(fā)按鍵 lines: 5, //分割行 rows: 5, //分割列 delay: 0, //ms,動(dòng)畫自動(dòng)執(zhí)行時(shí)間,默認(rèn)300毫秒,0為不觸發(fā) time: [1, 1.8], //動(dòng)畫時(shí)間范圍 }; $.fn.explode = function (options) { //保持this指向,此處沒有必要將this包在$號(hào)中如$(this),因?yàn)閠his已經(jīng)是一個(gè)jQuery對(duì)象。 var $self = this, _explode = { //初始化 init: function () { //執(zhí)行條件 options = $.extend(defaults, options); }, } // 生成隨機(jī)時(shí)間差 $.Random = function (start, end) { return Math.random() * (end - start) + start; } }(jQuery))
里面有些值得一說的代碼片段: var $self = this,以前我以為應(yīng)該是var $self = $(this),其實(shí)這里的this是指向觸發(fā)對(duì)象,例如$("#div").explode(),
所以這里的this === $("#div")?
其實(shí)不是,就算內(nèi)容一樣,但其實(shí)指向的堆棧不一樣,所以不相等.詳情可參考我之前寫的筆記關(guān)于基本類型和引用類型小知識(shí)
這是可配置項(xiàng),如果不懂用法可以百度一下,總的來說就合并成一個(gè)對(duì)象,有相同配置后面覆蓋前面的;
options = $.extend(defaults, options);
原文說的批量插入dom元素修改如下:
// 生成DOM createDom: function() { var i = 0, j = 0, width = $self.width(), height = $self.height(), w = width / options.lines, h = height / options.rows, str = ""; // 切割碎片 for (; i < options.rows; i++) { for (j = 0; j < options.lines; j++) { //填充截圖動(dòng)畫 var _left = j * w, _top = i * h; str += "" } }; return str; }
因?yàn)槎紱]什么難點(diǎn),就不說了,相信大家都看得明白
考慮到插件最好能解決大多數(shù)問題,用戶只要調(diào)用就完成效果,所以我把控制樣式也動(dòng)態(tài)加進(jìn)去
//添加歸為樣式 addStyle: function () { var $style = $("style"), _w = $self.width(), _style = "#wrapper div {background-image:url(" + $self.attr("data-img") + ")} #wrapper." + options.className + " div { opacity: 1!important; transform: perspective(" + _w + ") translate3d(0px, 0px, 0px) rotate(0deg) scale(1)!important; -moz-transform: perspective(" + _w + ") translate3d(0px, 0px, 0px) rotate(0deg) scale(1)!important; -webkit-transform: perspective(" + _w + ") translate3d(0px, 0px, 0px) rotate(0deg) scale(1)!important; }"; //已有樣式區(qū)域就追加文本,否則新增 $style.length ? $style.append(_style) : $("") .text(_style) .appendTo("body"); }
還有上面提到的觸發(fā)元素,就綁定跟解綁
//綁定 bind: function() { //如果有觸發(fā)元素 if(options.button) $(options.button).click(function() { $self.toggleClass(options.className); }) }, //移除綁定 destroy: function() { $(options.button).unbind("click") },
加個(gè)自動(dòng)執(zhí)行跟鏈?zhǔn)秸{(diào)用就差不多了,init改為這樣
//初始化 init: function() { //執(zhí)行條件 options = $.extend(defaults, options); //添加歸位樣式 this.addStyle(); //批量渲染DOM $self.append(this.createDom()); //綁定 this.bind(); //如果有自動(dòng)執(zhí)行要求,默認(rèn)300 if(options.delay) setTimeout(function() { $self.addClass(options.className); }, options.delay) //鏈?zhǔn)秸{(diào)用 return this; },
調(diào)用方式如下:
$(function() { $("#wrapper").explode({ className: "explode", button: $("#button"), lines: 5, rows: 5, delay: 300, time: [1, 2] }); })
嗯,簡(jiǎn)陋版就這樣了,下面是完整代碼:
美女
效果是出來的,弊端也很多
問題四:碎片沒有消失,衹是隱藏,很容易會(huì)遮擋住其他元素的交互事件,例如案例中的按鈕
問題五:能不能實(shí)現(xiàn)出在實(shí)際網(wǎng)站里,圖片碎片進(jìn)入,往下滑才會(huì)引發(fā)視圖下面的圖片執(zhí)行,更大可能是要結(jié)合懶加載插件使用
嗯,暫時(shí)想到這么多,雖然能力不過硬,有想法還是好的,以后慢慢完善,有人可以交流下會(huì)好點(diǎn)
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/106265.html
摘要:某天機(jī)緣巧合之下看到一文章然后被深深的迷上了鏈接在此用又學(xué)了一招,活變美女但是已經(jīng)了然后花幾天時(shí)間去封裝一下水平有限所以標(biāo)題注明簡(jiǎn)陋版首先我們用的女神圖片一基本框架搭建先來看看基本框架構(gòu)建長(zhǎng)這樣子我家女神點(diǎn)擊看美女現(xiàn)在來逐步分析一 某天,機(jī)緣巧合之下看到一文章,然后被深深的迷上了,鏈接在此brucelyy:用又學(xué)了一招,活變美女(但是已經(jīng)404了)然后花幾天時(shí)間去封裝一下,水平有限,所...
摘要:某天機(jī)緣巧合之下看到一文章然后被深深的迷上了鏈接在此用又學(xué)了一招,活變美女但是已經(jīng)了然后花幾天時(shí)間去封裝一下水平有限所以標(biāo)題注明簡(jiǎn)陋版首先我們用的女神圖片一基本框架搭建先來看看基本框架構(gòu)建長(zhǎng)這樣子我家女神點(diǎn)擊看美女現(xiàn)在來逐步分析一 某天,機(jī)緣巧合之下看到一文章,然后被深深的迷上了,鏈接在此brucelyy:用又學(xué)了一招,活變美女(但是已經(jīng)404了)然后花幾天時(shí)間去封裝一下,水平有限,所...
摘要:同時(shí)需要注意橫豎屏?xí)淹勇輧x的改變開始傾斜時(shí),記錄開始的陀螺儀位置,主體層的位置。檢測(cè)陀螺儀轉(zhuǎn)動(dòng)時(shí)間與插件的兼容角度傾斜進(jìn)行緩沖動(dòng)畫以上便是主要代碼,最好自己運(yùn)行調(diào)試下,運(yùn)用好動(dòng)畫函數(shù),理解每一個(gè)步驟。前端實(shí)現(xiàn)還有更牛的。 前端的3D(css3版本),其實(shí)是依托Css3的功勞,先上一個(gè)例子 http://antario.act.qq.com/代碼地址:鏈接:https://pan.b...
摘要:總的來說就是兩步生成小的元素,整齊的覆蓋在大的元素上,像下圖這樣為了方便看,把每個(gè)小元素,分開了些。鼠標(biāo)移入時(shí),讓所有小元素動(dòng)起來,主要是改變小元素的屬性的值具體實(shí)現(xiàn)的代碼也并不多,下面是注釋很詳細(xì)的代碼。 說明 和大家分享一個(gè)看上去很酷的效果,先來看效果圖吧! showImg(https://segmentfault.com/img/remote/1460000016194106);...
閱讀 3207·2021-09-22 15:05
閱讀 2763·2019-08-30 15:56
閱讀 1071·2019-08-29 17:09
閱讀 805·2019-08-29 15:12
閱讀 2087·2019-08-26 11:55
閱讀 3073·2019-08-26 11:52
閱讀 3382·2019-08-26 10:29
閱讀 1386·2019-08-23 17:19