前言
小白文采不好,大佬们看见了多多指点,自己的代码可能也有很多”毒瘤”希望大佬们指正,蟹蟹~~
在掘金看到了一个大佬发的 LOL六周年里的按钮动画 的文章
效果非常 very nice 也很有意思
于是进 lolSix周年活动页面 看看效果 只剩下哇塞!哇塞!哇塞!
于是自己决定试试,参考首页写一部分效果,于是… 有图有真相
ps: demo demo仓库
如果觉得不错的话,可以给个star鼓励一下 蟹蟹~~
两个动画都是通过改变class来完成的效果,简单粗暴 赞(≧▽≦)/\
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
| (function () { // 定义所需要的变量 let navBtns = $('#nav-ul i') let navBtnli = $('#nav-ul li') let navhs = $('#nav li') let navhem = $('#nav em') // 两个改变class的计数变量 let numLi = { numi: 1, numh: 1 } // 清楚定时器的变量 let time = null
// 鼠标经过和移除 触发run方法 navBtnli.on('mouseover', function () { let navI = $(this).children('i') run(navI, 'ans2_btn', numLi.numi) }) navBtnli.on('mouseout', function () { let target = $(this).children('i') stop(target) })
navhs.on('mouseover', function () { $(this).removeClass('ligb') let navh = $(this).children('em') run(navh, 'ans_btn', numLi.numh) })
navhs.on('mouseout', function () { let target = $(this).children('em') stop(target) $(this).addClass('ligb') })
// 接受三个参数, 需要改变的对象, 需要改变的名字, 需要改变的数 function run(obj, name, num) { // js定时器setTimeout 无法调用局部变量的解决办法 function runs() { if (num > 25) { num = 1 } obj.css('display', 'block') obj.removeClass() obj.addClass(nameNav + num) num++ time = setTimeout(function () { clearTimeout(time) runs() }, 30) } runs() } // 停止动画 function stop(target) { clearTimeout(time) target.css('display', 'none') }
})()
|
html结构请参考 官方页面或者我的仓库里面的html文件
然后就是中间的 flash 动画,使用了html object标签,
但是我在Ubuntu上面chrome测试的时候正常没有问题,(自己在Ubuntu开虚拟机上win测试,IE11,360有效果,chrome,firefox就没有了,懵逼 希望有大佬可以跟我提点一二)
但是在Firefox测试的时候不会显示,
于是用了兼容的处理方法,先贴一个通用的处理方法(自己也研究了一会儿,第一次接触2333~~),
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| // 这是活动页面的解决办法 // 大家也可以看看这个文档 https://github.com/swfobject/swfobject // An open source Javascript framework for detecting the Adobe Flash Player plugin and embedding Flash (swf) files. // 自己英文比较垃圾 chrome 翻译过来就是 // 用于检测Adobe Flash Player插件并嵌入Flash(swf)文件的开源Javascript框架。
// 这个文件可以引用腾讯的,也可以下载,也可以新建文件复制粘贴 <script src="./public/js/swfobject.js"></script> <script src="index.swf"></script> <script> var params = { scale: "noscale", wmode: "transparent", align: "middle", allowFullscreen: "true", allowScriptAccess: "always", FlashVars: "timer=1480586966506&endtimer=1481094000000" } swfobject.embedSWF("index.swf", "mymovie", "100%", "670", "8.0.0","expressInstall.swf", null, params); </script>
|
虽然解决了引入swf动画的兼容问题,但是在firefox上面根本不显示啊 23333~
大佬的解决办法非常简单 请继续细心观看文章!
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| // 提前在html结构上面写一个静态的替代图片,然后隐藏 <div class="logob">英雄联盟6周年盛典</div>
// 这里是swf文件的位置 <div id="mymovie" class="mymovie"></div>
// 通过判断 来显示静态图片(虽然没有了swf动画,但是总不不显示比较好 赞 学习了~!) setTimeout(function () { if ($(".mymovie").length > 0) { $(".logob").css({ "display": "block" }); } }, 1000)
|
大概就是跌么多了! 如果有不对的地方希望大佬们多多指正,
也可以加小白我交流2333~~ Qq: 952822399
自己大二也快要毕业了QAQ,希望被大佬们带走!!!