摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。預知后話地址為移動端而生的自定義多級聯(lián)動選擇器到此,的操作和手勢算法就已經(jīng)基本掌握了。
寫在前面
之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說說它的成長史~
在閱讀本文之前,確保你有稍微看過 MultiPicker 的源碼 喔~
點擊查看源碼 ,也可以在 npm 上找到他們:
日期選擇器 - DateSelector - NPM.
自定義json選擇器 - MultiPicker. NPM.
二、彈層的實現(xiàn) & DOM的小技巧 思考第3個問題:『如何實現(xiàn)彈層,使得插件能夠兼容更多框架,并且樣式上萬無一失?』回顧上集:如何造一個移動端的聯(liá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)。
我發(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)動選擇器,得到了很多人的關注。具體實現(xiàn)步驟如下先傳入一個需要計算深度的對象給,判斷如果還有則迭代,并計算深度。如果增加了聯(lián)動級數(shù)需要來判斷,則為新增加的聯(lián)動綁定新的事件。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說...
摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。具體實現(xiàn)步驟如下先傳入一個需要計算深度的對象給,判斷如果還有則迭代,并計算深度。如果增加了聯(lián)動級數(shù)需要來判斷,則為新增加的聯(lián)動綁定新的事件。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說...
摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。具體實現(xiàn)步驟如下先傳入一個需要計算深度的對象給,判斷如果還有則迭代,并計算深度。如果增加了聯(lián)動級數(shù)需要來判斷,則為新增加的聯(lián)動綁定新的事件。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說...
摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。預知后話地址為移動端而生的自定義多級聯(lián)動選擇器到此,的操作和手勢算法就已經(jīng)基本掌握了。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說說它的成長史~ 在閱讀本文之前,確保你有稍微看過 Mu...
摘要:寫在前面之前寫了一篇為移動端而生的自定義多級聯(lián)動選擇器,得到了很多人的關注。預知后話地址為移動端而生的自定義多級聯(lián)動選擇器到此,的操作和手勢算法就已經(jīng)基本掌握了。 寫在前面 之前寫了一篇 MultiPicker -『為移動端而生』的自定義多級聯(lián)動選擇器,得到了很多人的關注。鑒于很多人對這種手寫插件的過程很好奇,所以寫了幾篇文章,來說說它的成長史~ 在閱讀本文之前,確保你有稍微看過 Mu...
閱讀 3416·2021-11-24 09:39
閱讀 1806·2021-11-17 09:33
閱讀 3530·2021-10-12 10:12
閱讀 5037·2021-09-22 15:51
閱讀 1121·2019-08-30 13:11
閱讀 3580·2019-08-30 10:59
閱讀 573·2019-08-30 10:48
閱讀 1321·2019-08-26 13:48