国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

如何造一個移動端的聯(lián)動選擇器(二)

ivyzhang / 1120人閱讀

摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。預知后話地址為移動端而生的自定義多級聯(lián)動選擇器到此,的操作和手勢算法就已經(jīng)基本掌握了。

寫在前面

之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說說它的成長史~

在閱讀本文之前,確保你有稍微看過 MultiPicker 的源碼 喔~

點擊查看源碼 ,也可以在 npm 上找到他們:

日期選擇器 - DateSelector - NPM.

自定義json選擇器 - MultiPicker. NPM.

回顧上集:如何造一個移動端的聯(lián)動選擇器(一)

二、彈層的實現(xiàn) & DOM的小技巧 思考第3個問題:『如何實現(xiàn)彈層,使得插件能夠兼容更多框架,并且樣式上萬無一失?』

實現(xiàn)彈層的思路:【插入DOM → 初始化聯(lián)動的數(shù)據(jù) → 綁定事件 】

① 在插入DOM的部分( initDomFuc ),采用字符串拼接的方式插入DOM(而不是使用字符串模板)。

聯(lián)動的主要結(jié)構(gòu)式如下圖:

每個聯(lián)動是一個 div,div 包裹著一個 ul,ul 中的每個 li 就是聯(lián)動的值

其中div的高度是5個 li 的高度,ul的高度是實際的所有 li 的高度。

② 在初始化聯(lián)動數(shù)據(jù)的部分( initReady ),在頭尾分別插入兩個空字符,能夠起到占位符的作用,這樣在計算手勢的translate3d的時候更方便。

③ 為DOM元素綁定事件時,具體做法有兩步:

第一步:為每個初始化好的ul綁定touch事件( initReady );

第二步:為一些操作按鈕綁定事件( initBinding )。

③ - 第一步:touch事件的種類無非就是 touchstart、touchmove 和 touchend。但需要在每次滑動的時候記錄一些數(shù)據(jù)。這是為了實現(xiàn)一個滑動加速度的效果,下文會說到。

③ - 第二步:用到了自己封裝的一個簡單的事件監(jiān)聽函數(shù)on

這個函數(shù)主要用在【觸發(fā)】【取消】和【提交】這幾個重要按鈕上。

PS:在設計樣式的過程中考慮到,完整使用【年月日時分】五種時間單位的場景居多,為了優(yōu)化界面和用戶體驗,所以在日期選擇器的設計中,需要設計一種帶tab切換效果的完整版日期選擇器。其他場景中不會出現(xiàn)。

三、加速度的實現(xiàn) 思考第4個問題:『如何判斷滑動的手勢,讓滑動帶有加速度?』

我發(fā)現(xiàn),無論用戶使用哪個手指,只要用戶的滑動弧長在短時間內(nèi)比較大的話,說明用戶比較想快速向上滑或是向下滑。比如,在選擇出生年份的時候,用戶肯定會想快速滑到上面的部分,就會用很快速的手勢向下滑動一個比較大的弧長。這時候就應該有一個滑動加速度的效果。

那么如何實現(xiàn)呢,如何判斷用戶想要快速滑動呢?

很簡單,只需要考慮,單位時間內(nèi)的速度變化率,也就是加速度,就行了。

之前提到過,在touchmove的過程中會有一個 【speed數(shù)組】用來存儲滑動時,手勢的速度。

并在touchend中調(diào)用 initSpeed 函數(shù),確定最后 transition-duration 的值。

initSpeed 的主要工作是計算 speed 中的速度方差,方差和加速度是成正相關的。

所以當方差大于0.1時,ul 的實際滑動距離是手勢滑動距離的兩倍,transition-duration的值為0.2s;

而當方差小于0.1的時候,就認為基本是勻速滑動,ul 的實際滑動距等于手勢滑動距離,取 speed[0] 作為 transition-duration 的值。

確定好了滑動距離之后,就可以計算最后停留的位置 translate3d ( initPosition )。

滑動加速度的效果就基本實現(xiàn)了。

預知后話

Github地址:『為移動端而生』的自定義多級聯(lián)動選擇器

到此,dom的操作和手勢算法就已經(jīng)基本掌握了。

預知后話,后兩天見分曉

我是嘉寶Appian,一個賣萌出家的算法妹紙。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/115369.html

相關文章

  • 如何一個移動端的聯(lián)動選擇(四)

    摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。具體實現(xiàn)步驟如下先傳入一個需要計算深度的對象給,判斷如果還有則迭代,并計算深度。如果增加了聯(lián)動級數(shù)需要來判斷,則為新增加的聯(lián)動綁定新的事件。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說...

    ssshooter 評論0 收藏0
  • 如何一個移動端的聯(lián)動選擇(四)

    摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。具體實現(xiàn)步驟如下先傳入一個需要計算深度的對象給,判斷如果還有則迭代,并計算深度。如果增加了聯(lián)動級數(shù)需要來判斷,則為新增加的聯(lián)動綁定新的事件。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說...

    cgspine 評論0 收藏0
  • 如何一個移動端的聯(lián)動選擇(四)

    摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。具體實現(xiàn)步驟如下先傳入一個需要計算深度的對象給,判斷如果還有則迭代,并計算深度。如果增加了聯(lián)動級數(shù)需要來判斷,則為新增加的聯(lián)動綁定新的事件。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說...

    leiyi 評論0 收藏0
  • 如何一個移動端的聯(lián)動選擇

    摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。預知后話地址為移動端而生的自定義多級聯(lián)動選擇器到此,的操作和手勢算法就已經(jīng)基本掌握了。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說說它的成長史~ 在閱讀本文之前,確保你有稍微看過 Mu...

    leeon 評論0 收藏0
  • 如何一個移動端的聯(lián)動選擇

    摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。預知后話地址為移動端而生的自定義多級聯(lián)動選擇器到此,的操作和手勢算法就已經(jīng)基本掌握了。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說說它的成長史~ 在閱讀本文之前,確保你有稍微看過 Mu...

    wslongchen 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<