Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >分享几段有趣的代码(一)

分享几段有趣的代码(一)

作者头像
夏时
发布于 2018-06-26 08:43:05
发布于 2018-06-26 08:43:05
4K0
举报
文章被收录于专栏:夏时夏时

到处闲逛时经常能发现一些有趣的代码段,于是干脆来个大杂烩吧~

狡猾的标题栏

这个效果很多博客都使用了,看gif图:

很有趣是不是?实现的代码也很简单,在网页的任意地方加入即可:

  1. <script>  
  2. // 浏览器标题切换
  3. var OriginTitile = document.title;    // 保存之前页面标题
  4. var titleTime;  
  5. document.addEventListener('visibilitychange', function(){  
  6. if (document.hidden){  
  7.         document.title = '草榴社區主論壇 - 1024';  
  8.         clearTimeout(titleTime);  
  9.     }else{  
  10.         document.title = '生命-1s ~ ';  
  11.         titleTime = setTimeout(function() {  
  12.             document.title = OriginTitile;  
  13.         }, 2000); // 2秒后恢复原标题
  14.     }  
  15. });  
  16. </script>  

飘荡在页面左下角的蒲公英

这个也可以说是烂大街了……具体效果可以直接看本页面的左下角……

实现代码如下:

  1. <div class="dandelion">  
  2.     <span class="smalldan"></span>  
  3.     <span class="bigdan"></span>  
  4. </div>  
  5. <style type="text/css">  
  6. /* 在小屏幕自动隐藏 */  
  7. @media screen and (max-width:600px){  
  8.     .dandelion{display: none !important;}  
  9. }  
  10. .dandelion span {  
  11.     display: block;  
  12.     position: fixed;  
  13.     z-index: 9999999999;  
  14.     bottom: 0px;  
  15.     background-image: url();  
  16.     background-repeat: no-repeat;  
  17.     _background: none;  
  18.     /* 动画效果 */  
  19.     -webkit-animation: ball-x 3s linear 2s infinite;  
  20.     -moz-animation: ball-x 3s linear 2s infinite;  
  21.     animation: ball-x 3s linear 2s infinite;  
  22.     -webkit-transform-origin: bottom center;  
  23.     -moz-transform-origin: bottom center;  
  24.     transform-origin: bottom center;  
  25. }  
  26. /* 大的蒲公英样式 */  
  27. .dandelion .bigdan {  
  28.     width: 64px;  
  29.     height: 115px;  
  30.     left: 41px;  
  31.     background-position: -86px -36px;  
  32.     border: 0px solid #fff;  
  33. }  
  34. /* 小的蒲公英样式 */  
  35. .dandelion .smalldan {  
  36.     width: 36px;  
  37.     height: 60px;  
  38.     left: 88px;     
  39.     background-position: 0 -90px;  
  40.     border: 0px solid #fff;  
  41. }  
  42. /* 以下是动画效果 */  
  43. @keyframes ball-x {  
  44.     0% { transform:rotate(0deg);}  
  45.     25% { transform:rotate(5deg); }  
  46.     50% { transform:rotate(0deg);}  
  47.     75% { transform:rotate(-5deg);}  
  48.     100% { transform:rotate(0deg);}    
  49. }  
  50. @-webkit-keyframes ball-x {  
  51.     0% { -webkit-transform:rotate(0deg);}  
  52.     25% { -webkit-transform:rotate(5deg); }  
  53.     50% { -webkit-transform:rotate(0deg);}  
  54.     75% { -webkit-transform:rotate(-5deg);}  
  55.     100% { -webkit-transform:rotate(0deg);}  
  56. }  
  57. @-moz-keyframes ball-x {  
  58.     0% { -moz-transform:rotate(0deg);}  
  59.     25% { -moz-transform:rotate(5deg); }  
  60.     50% { -moz-transform:rotate(0deg);}  
  61.     75% { -moz-transform:rotate(-5deg);}  
  62.     100% { -moz-transform:rotate(0deg);}  
  63. }  
  64. </style>  

页面鼠标点击特效

效果嘛……你在本页不断点击鼠标左键就能看到了(千万别上瘾哦~)

实现的方法很简单,还是老套路,在页面的任意位置加入如下代码即可(需要引入 jQuery

  1. <script>  
  2. jQuery(document).ready(function($) {   
  3.     $("html,body").click(function(e){   
  4. var dfs=[  
  5. "您刚才的点击使计生局放开了"+Math.floor(Math.random()*100)+"胎政策。",  
  6. "您刚才的点击使黄石超级火山爆发了",  
  7. "您刚才的点击使罗辑又换了一个女朋友",  
  8. "您刚才的点击使小米公司收购了高通公司",  
  9. "您刚才的点击引爆了"+Math.random()*10000+"光年外的一颗恒星",  
  10. "您刚才的点击使头发变得乌黑浓密了",  
  11. "您刚才的点击使您的波函数坍塌了",   
  12. "您刚才的点击使您的银行卡被盗刷了",   
  13. "您刚才的点击使普朗克常数扩大了十倍",   
  14. "您刚才的点击熄灭了蓝色空间号二号主引擎",   
  15. "您刚才的点击创造了一个小宇宙",   
  16. "您刚才的点击使宇宙由开放转为闭合",   
  17. "您刚才的点击让云天明和关一帆在一起了",  
  18. "您刚才的点击使三体第"+Math.floor(Math.random()*100)+"舰队起航了",   
  19. "您刚才的点击使第"+Math.floor(Math.random()*10000)+"号宇宙毁灭了",   
  20. "您刚才的点击向太阳发射了一颗光粒",   
  21. "您刚才的点击导致三体行星撞上他的主星",  
  22. "您刚才的点击令人类文明将在"+(new Date()).getFullYear()+"年"+((new Date()).getMonth()+1)+"月"+(new Date()).getUTCDate()+"日23:59:59毁灭",  
  23. "您刚才的点击启动了威慑系统",  
  24. "您刚才的点击使谢顿计划脱离了正轨",  
  25. "您刚才的点击使程心按下了威慑开关",  
  26. "您刚才的点击引起了"+Math.random()*10000+"光年外一个行星的爆炸",  
  27. "您刚才的点击使宇宙中产生了一些暗物质",  
  28. "您刚才的点击引起了所有行星上的地震",  
  29. "您刚才的点击使一台诺基亚摔碎了",  
  30. "您刚才的点击使360云盘倒闭了",  
  31. "您刚才的点击小米发布了MIX概念手机",  
  32. "千万不要再次点击鼠标",  
  33. "真的千万不要再次点击鼠标"
  34.         ];  
  35. var n=Math.floor(Math.random() * dfs.length + 1)-1;   //随机获取一条数据
  36. var $i=$("<p/>").text(dfs[n]);      //新建一个b标签,并显示随机的话语
  37. var x=e.pageX,y=e.pageY;            //获取鼠标点击的x,和y
  38.         $i.css({                            //为标签赋予css值
  39. "z-index":99999,   
  40. "top":y-20,   
  41. "left":x,   
  42. "position":"absolute",   
  43. "color":"#E94F06",  
  44. "font-family":"微软雅黑",  
  45. "cursor":"default",  
  46. "-moz-user-select": "none",  
  47. "-webkit-user-select": "none",  
  48. "-ms-user-select": "none",  
  49. "-khtml-user-select": "none",  
  50. "user-select": "none",  
  51.         });   
  52.         $("body").append($i);               //在尾部插入
  53.         $i.animate( {"top":y-180,"opacity":0}, 1500, function(){$i.remove();});     //动画消除
  54.         e.stopPropagation();  
  55.     });  
  56. });   
  57. </script>  
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
详解分布式事务之 Seata-Client 原理及流程
在分布式系统中,分布式事务是一个必须要解决的问题,目前使用较多的是最终一致性方案。自年初阿里开源了Fescar(四月初更名为Seata)后,该项目受到了极大的关注,目前已接近 8000 Star。Seata 以高性能和零侵入的特性为目标解决微服务领域的分布式事务难题,目前正处于快速迭代中,近期小目标是生产可用的 Mysql 版本。
程序猿DD
2019/05/10
2.2K0
详解分布式事务之 Seata-Client 原理及流程
分布式事务中间件 Fescar - RM 模块源码解读
在SOA、微服务架构流行的年代,许多复杂业务上需要支持多资源占用场景,而在分布式系统中因为某个资源不足而导致其它资源占用回滚的系统设计一直是个难点。我所在的团队也遇到了这个问题,为解决这个问题上,团队采用的是阿里开源的分布式中间件Fescar的解决方案,并详细了解了Fescar内部的工作原理,解决在使用Fescar中间件过程中的一些疑虑的地方,也为后续团队在继续使用该中间件奠定了理论基础。
张乘辉
2019/07/10
6530
Seata分布式事务之TM、RM、TC源码分析
笔者通过绘制时序图,我们可以清晰的知道在集成Seata、ShardingSphere、Dubbo之后,我们插入一条数据的整个内部调用链逻辑
spilledyear
2022/05/13
2.6K0
Seata分布式事务之TM、RM、TC源码分析
Seata 源码篇之AT模式启动流程 - 下 - 04
上一篇文章,我们看了Seata AT模式一阶段提交流程,本文我们来看看AT模式的二阶段流程和全局事务提交回滚逻辑的实现。
大忽悠爱学习
2023/10/11
3490
Seata 源码篇之AT模式启动流程 - 下 - 04
seata TC 请求处理流程
TC的业务channelHandler为类 io.seata.core.rpc.netty.AbstractNettyRemotingServer.ServerHandler,注意到达该类的请求都是经过编解码的了,请求类型为RpcMessage。ServerHandler类处理方法有:
luoxn28
2021/01/28
9410
seata TC 请求处理流程
分布式事务之Seata中间件原理及流程详细分析
原文链接:https://blog.csdn.net/f4761/article/details/89077400
天涯泪小武
2019/10/22
2.2K0
分布式事务之Seata中间件原理及流程详细分析
Seata学习整理
在配车的业务中,我们使用了Seata的分布式事务来保证配车的业务逻辑能够正常时,才会做订单信息推送到财务系统。我们的系统配车业务一开始使用Seata的TCC模式来实现的,需要自己实现try和confirm或者cancel的逻辑。之后,由于seata推出了AT模式,之后系统采用的分布式事务使用的是AT模式。
路行的亚洲
2023/02/28
3740
Seata学习整理
深度剖析一站式分布式事务方案Seata-Cient
在之前的文章中已经介绍过Seata的总体介绍,如何使用以及Seata-Server的原理分析,有兴趣的可以阅读下面的文章:
用户5397975
2019/10/14
8350
深度剖析一站式分布式事务方案Seata-Cient
Apache ShardingSphere sharding-jdbc 分布式事务小练习
[技术标准] https://pubs.opengroup.org/onlinepubs/009680699/toc.pdf
前Thoughtworks-杨焱
2021/12/07
8570
​深入了解分布式事务组件 Seata (一)
分布式事务的问题,在微服务架构中一直是难题。单体应用实现本地事务即可,到了分布式环境,情况就变得复杂。一个请求可能涉及多个服务,上下游存在依赖关系,其中的一环失败,需要将整个事务回滚。笔者在去年上半年开源过一款微服务的分布式事务组件:lottor,基于可靠消息的柔性分布式事务实现方案。引入的 Lottor 客户端使用比较复杂,具有业务侵入性。推广使用的效果并不是很好。阿里在今年年初开源了 Seata(原名 fescar),引起了强烈的反响。笔者最近也在考虑改进 Lottor,借学习实践 Seata 的机会,和大家分享一下。
aoho求索
2019/10/20
1.3K0
seata TM源码分析
下面就一起来看下TM模块的实现原理,TM模块是seata中全局事务发起者和掌控者,其核心逻辑有:业务逻辑切面代理:对全局事务注册/提交操作。启动netty客户端:会启动TM/RM客户端与TC通信。数据源切面代理:SQL解析、分支事务注册/提交、undolog保存、分支事务状态上报。Rpc代理:在RPC流程中传递seata上下文(xid等,非本文分析重点)。
luoxn28
2021/01/28
1.3K0
seata TM源码分析
Seata AT 模式启动源码分析
从上一篇文章「分布式事务中间件Seata的设计原理」讲了下 Seata AT 模式的一些设计原理,从中也知道了 AT 模式的三个角色(RM、TM、TC),接下来我会更新 Seata 源码分析系列文章。今天就来分析 Seata AT 模式在启动的时候都做了哪些操作。
张乘辉
2019/12/02
6510
分布式事务:Seata框架AT模式及TCC模式执行流程剖析
管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚,在分支事务执行的客户端。
朝雨忆轻尘
2020/11/24
2.2K0
分布式事务:Seata框架AT模式及TCC模式执行流程剖析
Seata-Saga模式 原理
状态机设计组件:seata-saga-statemachine-designer 状态机在线画图工具:saga_designer
全栈程序员站长
2022/11/04
7020
Seata-Saga模式 原理
深度剖析 Seata TCC 模式【图解 + 源码分析】
Seata 目前支持 AT 模式、XA 模式、TCC 模式和 SAGA 模式,之前文章更多谈及的是非侵入式的 AT 模式,今天带大家认识一下同样是二阶段提交的 TCC 模式。
张乘辉
2022/01/24
2.9K0
深度剖析 Seata TCC 模式【图解 + 源码分析】
详解 Seata AT 模式事务隔离级别与全局锁设计
Seata AT 模式是一种非侵入式的分布式事务解决方案,Seata 在内部做了对数据库操作的代理层,我们使用 Seata AT 模式时,实际上用的是 Seata 自带的数据源代理 DataSourceProxy,Seata 在这层代理中加入了很多逻辑,比如插入回滚 undo_log 日志,检查全局锁等。
张乘辉
2022/01/04
3.2K0
详解 Seata AT 模式事务隔离级别与全局锁设计
[图文] Seata AT 模式分布式事务源码分析
AT 模式是 Seata 主推的分布式事务解决方案,最早来源于阿里中间件团队发布的 TXC服务,后来成功上云改名 GTS。相较于TCC而言,Seata的AT模式业务侵入性更低,易于接入。
田守枝
2019/07/11
2.6K0
[图文] Seata AT 模式分布式事务源码分析
防止内卷和被潜规则,Spring Cloud Alibaba微服务架构实战派(上下册)|35岁程序员那些事
在写这本书之前,我先后在两家杭州的“独角兽”公司担任技术负责人,并推进公司核心业务的“中台化”改造。在落地业务中台和技术中台的过程中,督促并指导开发人员统一使用Spring Cloud Alibaba作为中台服务最底层的基础框架。
35岁程序员那些事
2022/09/23
8320
防止内卷和被潜规则,Spring Cloud Alibaba微服务架构实战派(上下册)|35岁程序员那些事
深入了解分布式事务组件 Seata :AT 模式(二)
在前面一篇文章,我们介绍了阿里开源的分布式事务组件 Seata 的相关概念,重点介绍了 Seata 的 AT 模式。并通过一个 Spring-Cloud-JPA 的案例,演示了 AT 模式的使用入门。本文将会结合 Spring-Cloud-JPA 的案例,深入了解 Seata AT 模式的工作流程。本文基于 v0.8.1。
aoho求索
2019/12/15
1.6K0
seata TC启动流程分析
seata-server 启动方法 io.seata.server.Server#main,默认启动端口 SERVER_DEFAULT_PORT = 8091。main方法主要是解析并设置一些配置,初始化几个线程池,启动DefaultCoordinator和Netty服务等,源码如下:
luoxn28
2021/01/28
8750
seata TC启动流程分析
推荐阅读
相关推荐
详解分布式事务之 Seata-Client 原理及流程
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档