亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

vue 實現 ios 原生picker 效果及實現思路解析

2019-11-19 14:46:58
字體:
來源:轉載
供稿:網友

以前最早實現了一個類似的時間選擇插件,但是適用范圍太窄,索性最近要把這個實現方式發布出來,就重寫了一個高復用的vue組件。

支持安卓4.0以上,safari 7以上

效果預覽

gitHub

滾輪部分主要dom結構

<template data-filtered="filtered"> <div class="pd-select-item">  <div class="pd-select-line"></div>  <ul class="pd-select-list">   <li class="pd-select-list-item">1</li>  </ul>  <ul class="pd-select-wheel">   <li class="pd-select-wheel-item">1</li>  </ul> </div></template>propsprops: {   data: {    type: Array,    required: true   },   type: {    type: String,    default: 'cycle'   },   value: {}  }

設置css樣式 使其垂直居中

.pd-select-line, .pd-select-list, .pd-select-wheel {  position: absolute;  left: 0;  right: 0;  top: 50%;  transform: translateY(-50%);}.pd-select-list {  overflow: hidden;}

滾輪3d樣式設置

/* 滾輪盒子 */.pd-select-wheel {  transform-style: preserve-3d;  height: 30px;}/* 滾輪單項 */.pd-select-wheel-item {  white-space: nowrap;  text-overflow: ellipsis;  backface-visibility: hidden;  position: absolute;  top: 0px;  width: 100%;  overflow: hidden;}

主要注意2個屬性 transform-style: preserve-3d; backface-visibility: hidden;

第一個是3d布局,讓界面3D化,第二個是讓滾輪背后自動隱藏(上圖紅色部分,背面的dom節點 會自動隱藏)

如何實現3D 滾輪

盒子主要這句css transform: rotate3d(1, 0, 0, x deg);

item主要運用這句css transform: rotate3d(1, 0, 0, xdeg) translate3d(0px, 0px, [x]px);


上面2張圖展示了translate3d(0px, 0px, [x]px);這句話的效果 [x]就是圓的半徑

從上面的圖可以看見,我們只需旋轉每個dom自身,然后利用translate3d(0px, 0px, [x]px);把每個dom擴展開

就形成了圓環.α就是每個dom自身旋轉的角度,因為這里只用了0到180°,所以用了個盒子在裝這些dom

行高 和角度計算

已知兩邊和夾角 算第三邊長度 ~=34px

http://tool.520101.com/calculator/sanjiaoxingjiaodu/

無限滾輪實現

/* 滾輪展示大小限定 */spin: {start: 0, end: 9, branch: 9} /* 獲取spin 數據 */ getSpinData (index) {  index = index % this.listData.length  return this.listData[index >= 0 ? index : index + this.listData.length] } /* 模運算 獲取數組有的索引 這樣就構成 圓環了 */

touchend做特殊處理

在touchend 里設置setCSS類型 把滾動數據取整,這樣停止的時候就是

一格一格的準確轉動到位

// other code ..../* 計算touchEnd移動的整數距離 */    let endMove = margin    let endDeg = Math.round(updateDeg / deg) * deg    if (type === 'end') {     this.setListTransform(endMove, margin)     this.setWheelDeg(endDeg)    } else {     this.setListTransform(updateMove, margin)     this.setWheelDeg(updateDeg)    } // other code ....慣性緩動// other code ....setWheelDeg (updateDeg, type, time = 1000) {    if (type === 'end') {     this.$refs.wheel.style.webkitTransition = `transform ${time}ms cubic-bezier(0.19, 1, 0.22, 1)`     this.$refs.wheel.style.webkitTransform = `rotate3d(1, 0, 0, ${updateDeg}deg)`    } else {     this.$refs.wheel.style.webkitTransition = ''     this.$refs.wheel.style.webkitTransform = `rotate3d(1, 0, 0, ${updateDeg}deg)`    }   }setListTransform (translateY = 0, marginTop = 0, type, time = 1000) {    if (type === 'end') {     this.$refs.list.style.webkitTransition = `transform ${time}ms cubic-bezier(0.19, 1, 0.22, 1)`     this.$refs.list.style.webkitTransform = `translateY(${translateY - this.spin.branch * 34}px)`     this.$refs.list.style.marginTop = `${-marginTop}px`     this.$refs.list.setAttribute('scroll', translateY)     console.log('end')    } else {     this.$refs.list.style.webkitTransition = ''     this.$refs.list.style.webkitTransform = `translateY(${translateY - this.spin.branch * 34}px)`     this.$refs.list.style.marginTop = `${-marginTop}px`     this.$refs.list.setAttribute('scroll', translateY)    }}// other code ....

獲取當前選中值

/* 在設置完css后獲取值 */setStyle (move, type, time) {  // ...other code  /* 設置$emit 延遲 */  setTimeout(() => this.getPickValue(endMove), 1000) // ...other code}/* 獲取選中值 */   getPickValue (move) {    let index = Math.abs(move / 34)    let pickValue = this.getSpinData(index)    this.$emit('input', pickValue)   }

初始化設置

mounted () {   /* 事件綁定 */   this.$el.addEventListener('touchstart', this.itemTouchStart)   this.$el.addEventListener('touchmove', this.itemTouchMove)   this.$el.addEventListener('touchend', this.itemTouchEnd)   /* 初始化狀態 */   let index = this.listData.indexOf(this.value)   if (index === -1) {    console.warn('當前初始值不存在,請檢查后listData范圍!!')    this.setListTransform()    this.getPickValue(0)   } else {    let move = index * 34    /* 因為往上滑動所以是負 */    this.setStyle(-move)    this.setListTransform(-move, -move)   }

當展示為非無限滾輪的時

這里我們很好判斷,就是滾動的距離不能超過原始數的數組長度*34,且不能小于0(實際代碼中涉及方向)

/* 根據滾輪類型 line or cycle 判斷 updateMove最大距離 */    if (this.type === 'line') {     if (updateMove > 0) {      updateMove = 0     }     if (updateMove < -(this.listData.length - 1) * singleHeight) {      updateMove = -(this.listData.length - 1) * singleHeight     }    } /* 根據type 控制滾輪顯示效果 */   setHidden (index) {    if (this.type === 'line') {     return index < 0 || index > this.listData.length - 1    } else {     return false    }   },

dom結構也增加了對應的響應

<div class="pd-select-item">  <div class="pd-select-line"></div>  <div class="pd-select-list">   <ul class="pd-select-ul" ref="list">    <li class="pd-select-list-item" v-for="el,index in renderData " :class="{'hidden':setHidden(el.index)}" :key="index">{{el.value}}</li>   </ul>  </div>  <ul class="pd-select-wheel" ref="wheel">   <li class="pd-select-wheel-item" :class="{'hidden':setHidden(el.index)}" :style="setWheelItemDeg(el.index)" :index="el.index" v-for="el,index in renderData " :key="index">{{el.value}}</li>  </ul> </div>

總結

以上所述是小編給大家介紹的vue 實現 ios 原生picker 效果及思路解析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
热99精品里视频精品| 欧美专区国产专区| 欧美激情亚洲国产| 91欧美视频网站| 久久久精品久久久久| 一区二区日韩精品| 久久久国产精品视频| 亚洲人成在线一二| 一区二区三区无码高清视频| 日韩理论片久久| 亚洲剧情一区二区| 91久久久久久久一区二区| 欧美精品久久久久| 久久成人18免费网站| 欧美日韩在线免费观看| 在线观看免费高清视频97| 91在线免费网站| 亚洲成av人影院在线观看| 国产精品嫩草影院一区二区| 久久婷婷国产麻豆91天堂| 久久视频免费在线播放| 日韩高清欧美高清| 国产69精品99久久久久久宅男| 国产视频久久久久久久| 日韩中文视频免费在线观看| 亚洲国产精品人人爽夜夜爽| 蜜臀久久99精品久久久久久宅男| 国外日韩电影在线观看| 高清日韩电视剧大全免费播放在线观看| 57pao成人国产永久免费| 亚洲乱码一区二区| 不卡av在线播放| 成人日韩在线电影| 91久久综合亚洲鲁鲁五月天| 国产精品激情av电影在线观看| 欧美日韩国产精品一区二区不卡中文| 日韩亚洲欧美中文在线| 韩国19禁主播vip福利视频| 欧美激情亚洲另类| 国产午夜精品理论片a级探花| 亚洲性生活视频在线观看| 亚洲色在线视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲精品美女久久久久| 国产精品露脸av在线| 另类视频在线观看| 欧美激情一区二区三区久久久| 日本久久久a级免费| www.欧美精品一二三区| 国产精品海角社区在线观看| 亚洲精品国产电影| 国产欧美日韩中文字幕在线| 成人写真视频福利网| 国语自产精品视频在线看抢先版图片| 色妞欧美日韩在线| 亚洲国产精品久久久久久| 激情久久av一区av二区av三区| 久久视频国产精品免费视频在线| 色yeye香蕉凹凸一区二区av| 精品久久久久人成| 91免费版网站入口| 国产精品99久久久久久久久久久久| 亚洲国产精品yw在线观看| 国产一区二区三区在线免费观看| 国产日韩精品视频| 亚洲天堂av在线免费| 国产福利精品在线| 神马久久久久久| 欧美高清不卡在线| 蜜月aⅴ免费一区二区三区| 国产精品一二区| 中文字幕无线精品亚洲乱码一区| 国产成人综合亚洲| 亚洲欧美综合区自拍另类| 日韩av有码在线| 成人综合网网址| 欧美性20hd另类| 成人精品网站在线观看| 国产一区二区三区直播精品电影| 国产午夜精品理论片a级探花| 国产精品久久久久av免费| 亚洲欧美制服另类日韩| 日韩亚洲第一页| 亚洲人a成www在线影院| 在线色欧美三级视频| 亚洲天堂av女优| 最近免费中文字幕视频2019| 久久精品国产一区| 亚洲精品久久久久国产| 久久久久久久久久婷婷| 欧美在线视频免费播放| 亚洲成人三级在线| 久久久午夜视频| 国产一区二区三区在线观看视频| 国产69精品久久久久9| 欧美麻豆久久久久久中文| 欧美制服第一页| 亚洲国产精品人久久电影| 亚洲女成人图区| 久久九九热免费视频| 国产精品久久久久久久久久久久久久| 欧美一级大片在线观看| 97在线视频免费| 成人欧美一区二区三区在线| 午夜精品国产精品大乳美女| 黑人巨大精品欧美一区二区三区| 91精品国产乱码久久久久久久久| 日韩欧美中文字幕在线观看| 国模精品系列视频| 欧美激情按摩在线| 国产精品午夜国产小视频| 国产精品爽黄69天堂a| 一区二区欧美激情| 亚洲国产精品久久久久秋霞蜜臀| 这里只有精品视频| 亚洲欧美日韩国产成人| 一本色道久久综合狠狠躁篇怎么玩| 欧美黑人国产人伦爽爽爽| 久久国产加勒比精品无码| 欧美午夜www高清视频| 亚洲国内高清视频| 国产精品第3页| 日韩欧美在线视频免费观看| 日韩欧美一区二区三区久久| 91精品国产电影| 亚洲www永久成人夜色| 欧美电影免费观看电视剧大全| 久久久久久久久久久91| 欧美一级成年大片在线观看| 日韩中文字幕网址| 国产美女91呻吟求| 在线观看国产欧美| 色偷偷88888欧美精品久久久| 久久久视频在线| 欧美极品少妇xxxxx| 在线电影欧美日韩一区二区私密| 一道本无吗dⅴd在线播放一区| 亚洲日本中文字幕免费在线不卡| 亚洲激情电影中文字幕| 在线看国产精品| 精品呦交小u女在线| 国产亚洲精品美女久久久久| 亚洲娇小xxxx欧美娇小| 国产成人涩涩涩视频在线观看| 国产精品www色诱视频| 亚洲男人第一av网站| 欧美另类第一页| 久久综合久久美利坚合众国| 国产精品人人做人人爽| 欧美午夜精品在线| 性欧美亚洲xxxx乳在线观看| 一本色道久久综合狠狠躁篇怎么玩| 中文字幕亚洲一区二区三区五十路| 亚洲欧美日韩天堂| 午夜精品一区二区三区在线播放| 亚洲最大中文字幕| 久久天天躁狠狠躁夜夜躁| 日韩成人高清在线| 91av福利视频| 国产精品99久久久久久www| 国产精品久久久91| 97在线视频免费观看| 全球成人中文在线| 久久视频精品在线|