欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

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

效果如圖

準(zhǔn)備食材(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表示的是觸摸彈出的小圓圈。

準(zhǔn)備輔料 (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相對(duì)定位,給小圓圈絕對(duì)定位,再給小圓圈添加動(dòng)畫navCircle,采用css3的縮放使其變大,至于為什么是200倍和.4s呢,經(jīng)過測(cè)試這樣更人性化,其余的倍數(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)

   }

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

友情提示!touchend僅支持移動(dòng)端

結(jié)束

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

相關(guān)文章

  • js 第二代身份證號(hào)碼的驗(yàn)證機(jī)制代碼

    js 第二代身份證號(hào)碼的驗(yàn)證機(jī)制代碼

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

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

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

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

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

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

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

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

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

    Bootstrap每天必學(xué)之面板

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

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

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

    Javascript中replace()小結(jié)

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

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

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

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

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

最新評(píng)論