亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

原生js實現(xiàn)簡單的Ripple按鈕實例代碼

 更新時間:2017年03月24日 10:25:59   作者:cleartime  
本篇文章主要介紹了原生js實現(xiàn)簡單的Ripple按鈕實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。

整理文檔,搜刮出一個原生js實現(xiàn)簡單的Ripple按鈕的代碼,稍微整理精簡一下做下分享。

效果如圖

準備食材(html部分)

 <ul id="nav">
  <li>
   <a href='#'>
    <span>首頁</span>
   <span class="circle"></span>
   </a>
  </li>
  <li>
   <a href='#'>
    <span>我的</span>
   <span class="circle"></span>
   </a>
  </li>
  <li>
   <a href='#'>
    <span>更多</span>
   <span class="circle"></span>
   </a>
  </li>
 </ul>

典型的菜單li布局,里面的span.circle表示的是觸摸彈出的小圓圈。

準備輔料 (css部分)

 #nav {
 display: flex;
 }
 #nav li {
 position: relative;
 overflow: hidden;
 flex: 1;
 }
 li a {
  display: flex;
 flex-direction: column;
 justify-content: center;
 align-items: center;
 }

 .circle{
 position: absolute;
 background: rgba(86,187,247,.1);
 width: 1px;
 height: 1px;
 top:50%;
 left: 50%;
 border-radius: 50%;
 }
 .circle.act{
  animation: navCircle .4s;
 }

 @keyframes navCircle
 {
 from {transform: scale(0);border-radius: 50%;}
 to {transform:scale(200);border-radius: 50%;}
 }

我的思路是這樣的,給li相對定位,給小圓圈絕對定位,再給小圓圈添加動畫navCircle,采用css3的縮放使其變大,至于為什么是200倍和.4s呢,經(jīng)過測試這樣更人性化,其余的倍數(shù)你們也可以試試。

大火烹飪 (js部分)

 var li = document.getElementById('nav').querySelectorAll('li');
 var circle = document.getElementById('nav').querySelectorAll('.circle');
   for(var i=0,len = li.length;i<len;i++){
    ((i)=>{
    li[i].addEventListener('click',(e)=>{
     circle[i].setAttribute('class','circle act');
     circle[i].setAttribute('style','top:'+e.layerY+'px;left:'+e.layerX+'px');
    });

    li[i].addEventListener('touchend',()=>{
     circle[i].setAttribute('class','circle');
    })
    })(i)

   }

代碼很簡單,相信大家也猜到了,點擊li的時候給小圓圈添加class 'act',并且設(shè)置小圓圈的起始位置,監(jiān)聽觸摸結(jié)束的時候,取消class 'act',有人肯定要問了,為什么你不用touchstart呢,唉,因為沒有layerY這個屬性,找了半天都沒找到啊。還有為什么不用forEach,有的瀏覽器不支持啊,淚奔= = !

友情提示!touchend僅支持移動端

結(jié)束

做這個部分是因為我們安卓app里面有這個功能,所以我就想看看h5怎么做,開始的思路是讓寬度和高度隨著時間變大,但是實現(xiàn)了之后感覺性能不好,所以才想到了直接增加倍數(shù)唄,于是這個功能變完美誕生了,開始享用這份套餐把 !

相關(guān)文章

  • js 第二代身份證號碼的驗證機制代碼

    js 第二代身份證號碼的驗證機制代碼

    在盛大某網(wǎng)站注冊的時候,身份證必填,但我又不想填真實身份證號碼,于是隨便編了串自認為合法的身份證號碼,但是卻馬上被提示號碼錯誤
    2011-05-05
  • JS實現(xiàn)常見的查找、排序、去重算法示例

    JS實現(xiàn)常見的查找、排序、去重算法示例

    這篇文章主要介紹了JS實現(xiàn)常見的查找、排序、去重算法,結(jié)合實例形式總結(jié)分析了JavaScript線性查找、二分查找、遞歸查找、數(shù)組去重、冒泡拍戲、快速排序?qū)崿F(xiàn)技巧,需要的朋友可以參考下
    2018-05-05
  • js?實現(xiàn)picker?選擇器示例詳解

    js?實現(xiàn)picker?選擇器示例詳解

    這篇文章主要為大家介紹了js?實現(xiàn)picker?選擇器示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • js奇偶數(shù)判斷的代碼

    js奇偶數(shù)判斷的代碼

    js奇偶數(shù)判斷的代碼...
    2007-05-05
  • js回文數(shù)的4種判斷方法示例

    js回文數(shù)的4種判斷方法示例

    這篇文章主要給大家介紹了關(guān)于js回文數(shù)的4種判斷方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用js具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • Bootstrap每天必學之面板

    Bootstrap每天必學之面板

    Bootstrap每天必學之面板,面板(Panels)是Bootstrap框架新增的一個組件,其主要作用就是用來處理一些其他組件無法完成的功能,對面板感興趣的小伙伴們可以參考一下
    2015-11-11
  • 前端彈出對話框 js實現(xiàn)ajax交互

    前端彈出對話框 js實現(xiàn)ajax交互

    這篇文章主要為大家詳細介紹了前端彈出對話框,js實現(xiàn)ajax交互,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Javascript中replace()小結(jié)

    Javascript中replace()小結(jié)

    在javascript中,replace方法是屬于String對象的,可用于替換字符串。今天我們就來詳細探討下一些replace()方法的使用
    2015-09-09
  • JavaScript數(shù)組及非數(shù)組對象的深淺克隆詳解原理

    JavaScript數(shù)組及非數(shù)組對象的深淺克隆詳解原理

    JavaScript中數(shù)組的方法種類眾多,在ES3-ES7不同版本時期都有新方法;并且數(shù)組的方法還有原型方法和從object繼承的方法,本文介紹了JavaScript數(shù)組及非數(shù)組對象的深淺克隆,希望讀者能從中有所收獲
    2021-10-10
  • JavaScript如何刪除字符串中子字符串

    JavaScript如何刪除字符串中子字符串

    本文介紹了如何從?JavaScript?中的字符串中刪除子字符串,并提供了兩種常用的方法:replace()?方法和?split()?方法,結(jié)合示例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2023-05-05

最新評論