日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript基于SVG的圖片切換效果實例代碼

瀏覽:25日期:2023-06-12 14:11:42

最近太忙了,自動來到rjxy后,不曉得怎么回事,忙的都沒時間更博了。

昨天還有個同學跟我說,你好久沒更新博客了。。

甚為慚愧~~

正好12月來了,今天開一篇。

最近上課講到了 SVG,不曉得同學們理解到沒。 -_-!!!

圖片輪播見的太多,今天就用 SVG 寫了一個圖片輪播,效果如下。

JavaScript基于SVG的圖片切換效果實例代碼

效果要求

點擊控制塊,圖片切換。切換的時候使用圓形做遮罩,由小到大變化。每次切換的時候,圓的位置隨機產生。

主要知識點

1. SVG 的裁切(遮罩),clip-path 的運用。

2. SVG 利用 JS 更改層級。因為 SVG 不支持 CSS 的 z-index 更改層級,它永遠只會讓后面的標簽蓋住前面的標簽。

所以,我就利用 JS 的 appendChild 方法,讓每次展示的圖片,都移動位置到 SVG 的最后---- 話說我真是聰明。

// 更改當前圖片的層級為最頂層,也就是放到 SVG 的最后,它會覆蓋前面的圖片。bannerSvg.appendChild( pic[index ]);

3. 圓圈的放大,我用的是 requestAnimationFrame 方法。比傳統計時器 setInterval 和 setTimeout 節約資源太多。具體大家可以百度下。

4. 控制塊,利用的 DOM 根據展示的圖片個數動態生成。

HTML代碼

<svg id='banner'> <defs> <clipPath id='c1'> <circle cx='350' cy='196' r='20'></circle> </clipPath > </defs> <a xlink: rel='external nofollow' > <image x='0' y='0' xlink:href='http://www.b3g6.com/bcjs/images/1.jpg' rel='external nofollow' ></image> </a> <a xlink: rel='external nofollow' > <image x='0' y='0' xlink:href='http://www.b3g6.com/bcjs/images/2.jpg' rel='external nofollow' ></image> </a> <a xlink: rel='external nofollow' > <image x='0' y='0' xlink:href='http://www.b3g6.com/bcjs/images/3.jpg' rel='external nofollow' ></image> </a></svg><ul class='ul'> <!-- 空著,等 js 動態生成 --></ul>

CSS 代碼

.ul { display: flex; list-style: none;}.ul li{ background: #eee; padding-left: 20px; padding-right: 20px; margin-left: 4px; margin-right: 4px;}.ul .on{ background: #f30; color: #fff;}

JavaScript 代碼

let nowpic = 0 ;let myani = null;let radius = 0;// 找標簽let bannerSvg = document.getElementById('banner');let circle = document.getElementById('circle');let ul = document.getElementById('ul');let li = [];let pic = bannerSvg.querySelectorAll('.banner_img');// 控制塊初始化。for( let i=0 ; i <= pic.length-1 ; i++ ){ // 生成 li 標簽 let childLi = document.createElement('li'); // 添加 li 內容,為當前數字 childLi.innerHTML = i+1 ; // 把 li 分別放入 ul 標簽 和 數組 li 中。 ul.appendChild(childLi); li.push(childLi);}li[0].classList.add('on');// 遮罩圓動畫let circleAni = function(){ console.info(radius); radius += 20; radius = Math.min(800, radius); circle.style.r = radius +'px'; myani = requestAnimationFrame(circleAni); if( radius >= 800 ){ cancelAnimationFrame( myani ); }};// 顯示圖片的函數let showPic = function(index){ for(let i=0 ; i<=pic.length-1 ; i++ ){ // 控制塊變化 li[i].classList.remove('on'); // 不顯示的圖片不需要遮罩。 pic[i].children[0].setAttribute('clip-path',''); } // 更改當前圖片的層級為最頂層,也就是放到 SVG 的最后,它會覆蓋前面的圖片。 bannerSvg.appendChild( pic[index ]); // 退出上一步動畫 cancelAnimationFrame( myani ); // 遮罩圓半徑初始化為 0 radius = 0 ; circle.style.r = radius+'px'; // 遮罩圓的圓心(也就是位置)隨機。 circle.setAttribute('cx',Math.random()*700); circle.setAttribute('cy',Math.random()*303); // 給指定的圖片添加遮罩 clip-path pic[index].children[0].setAttribute('clip-path','url(#c1)'); // 執行 circle 動畫 myani = requestAnimationFrame(circleAni); // circle 動畫 // 控制塊的變化 li[index].classList.add('on');} showPic(0); // 默認顯示第一張for( let i=0 ; i<= li.length-1 ; i++ ){ li[i].addEventListener('click',function(){ showPic(i); });}

到此這篇關于JavaScript基于SVG的圖片切換效果實例代碼的文章就介紹到這了,更多相關js svg圖片切換效果內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩欧美2区| 国产精品.xx视频.xxtv| 国产精品主播在线观看| 日韩精品视频中文字幕| 国产午夜精品一区在线观看| 国产激情一区| 男人的天堂久久精品| 夜夜精品视频| 日韩高清在线观看一区二区| 国产精品天堂蜜av在线播放| 日韩精品视频一区二区三区| 91九色综合| 97精品视频在线看| 亚洲成人精品| 日韩精品一级| 久久亚洲精品中文字幕| 亚洲国产成人二区| 国产精品97| 国产伦理久久久久久妇女| 精品理论电影在线| 久久精品国产99久久| 日韩和欧美一区二区三区| 成人在线视频区| 鲁大师影院一区二区三区| 日韩午夜视频在线| 久久99蜜桃| 国产亚洲精品v| 欧美国产视频| 久久av在线| 精品午夜av| 日韩中文字幕不卡| 一区二区三区四区日本视频| 亚洲影院天堂中文av色| 蜜桃av.网站在线观看| 日韩一二三区在线观看| 国产主播一区| 卡一卡二国产精品| 久色成人在线| 激情综合自拍| 免费看av不卡| 日韩一区二区三区免费视频| 欧美丝袜一区| 中文字幕成在线观看| 国产亚洲精品美女久久 | 99成人在线| 日韩伦理福利| 久久精品毛片| 国产免费av国片精品草莓男男| 亚洲黄色免费看| 欧美激情三区| 国产另类在线| 久久国产高清| 不卡一区2区| 欧美日韩激情在线一区二区三区| 日韩不卡一二三区| 久久精品在线| 亚洲成人国产| 久久久精品网| 欧美va天堂| 国产精品videossex久久发布 | 亚洲高清av| 久久影院午夜精品| 日韩欧美中文| 91精品xxx在线观看| av资源亚洲| av中文字幕在线观看第一页 | 亚洲精品亚洲人成在线观看| 久久久成人网| 三级久久三级久久久| 捆绑调教日本一区二区三区| 国产日韩一区二区三免费高清| 欧美特黄一级| 精品色999| 亚洲欧美日韩在线观看a三区| 久久影院午夜精品| 超级白嫩亚洲国产第一| 国产精品亲子伦av一区二区三区| 综合视频一区| 蜜桃av一区二区三区电影| 99久久久久国产精品| 欧美日韩在线观看首页| 国产成人a视频高清在线观看| 国产一区二区色噜噜| 欧美91在线|欧美| 国产欧洲在线| 99国产精品视频免费观看一公开| 黄色av日韩| 在线日韩一区| 日韩在线一二三区| 免费一级欧美片在线观看网站 | 久久久久观看| 国产精品久久久久蜜臀 | 久久精品一本| 午夜精品久久久久久久久久蜜桃| 久久精品99久久无色码中文字幕| 一区二区视频欧美| 久久精品72免费观看| 精品国产乱码久久久久久樱花| 国内精品麻豆美女在线播放视频| 毛片在线网站| 中文字幕一区二区三区四区久久 | 日韩在线欧美| 亚洲日本国产| 日韩一区二区在线免费| 日本在线一区二区三区| 高清精品久久| 日本综合视频| 99在线精品视频在线观看| 另类小说一区二区三区| 亚洲综合婷婷| 98精品久久久久久久| 久久精品72免费观看| 在线免费观看亚洲| 美女亚洲一区| 日韩精品水蜜桃| 成人国产精品久久| 国产欧美一区二区三区国产幕精品| 九九久久电影| 国产91精品对白在线播放| 国产精品毛片久久久| 手机精品视频在线观看| 日本一二区不卡| 欧美激情一区| 国产精品伦一区二区| 日韩不卡一区二区| 国产亚洲网站| 免费中文字幕日韩欧美| 亚洲在线观看| 国产精品婷婷| 亚洲美女久久| 日韩欧美2区| 国产精品久久久久久久久久久久久久久| 亚洲日本欧美| 国产欧美日韩精品高清二区综合区 | 久久国产精品亚洲77777| 国产精品日韩欧美一区| 日韩视频久久| 国产探花在线精品一区二区| 亚洲精品美女91| 久久香蕉精品| 人人爽香蕉精品| 午夜精品影视国产一区在线麻豆| 日韩欧美久久| 国产精品极品| 国产在线日韩精品| 久久久国产精品一区二区中文| 亚洲成人av观看| 亚洲精品网址| 久久亚洲影院| 国产一区二区三区久久久久久久久| 精品久久精品| 欧美日韩精品在线一区| 日韩中文字幕91| 久久精品女人| 亚洲一区国产| 欧美精品影院| 欧美xxxx中国| 中文一区一区三区免费在线观| 日韩福利一区| 超碰成人av| 91精品久久久久久久久久不卡| 日韩一区二区三区高清在线观看| 国产欧美日韩综合一区在线播放| 欧美日韩一区二区高清| 精品视频一区二区三区在线观看 | 欧美成人亚洲| 国产精品一页| 久久aⅴ国产紧身牛仔裤| 欧美成人一二区| 精品捆绑调教一区二区三区| 欧美日韩国产高清电影| 亚洲精品精选| 久久精品观看| 久久久久久一区二区| 久久精品97| 国产精品视频一区视频二区| 1000部精品久久久久久久久| 国产精品美女午夜爽爽| 免费日韩视频| 亚洲香蕉网站| 国产精品99一区二区三区| 在线看片日韩| 国产亚洲亚洲| 欧美1区2区3区| 美女av一区| 中文字幕成人| 亚洲综合精品| 91久久中文| 91久久亚洲| 91久久视频| 中文日韩在线| 一区二区不卡| 国产日韩高清一区二区三区在线 | 一区二区三区四区在线看| 91嫩草亚洲精品| 亚洲一区免费| 视频一区视频二区中文| 黄色成人精品网站| 91亚洲精品视频在线观看| 精品三区视频|