JS+CSS实现漂亮的日历特效(仿win10系统日历)

复刻Win10鼠标特效

初衷:无意见发现win10的系统日鼠标悬浮的特效非常好看,想尝试一下用CSS和JS实现一下。

先上一下目前实现的效果图:

效果图.gif

难点是这种间隔效果和鼠标移动效果的实现,如下图

间隔效果的实现我采用了

background-clip: content-box;
padding: 2px;
background-color: gray;
border: 1px solid gray;

样式,为border和content加上颜色,并通过设置background-clip: content-box;将padding进行透明处理。

鼠标移动效果则是使用JS监听鼠标相对位置,通过设置和移动背景的位置实现,颜色和透明度的变化则是通过CSS渐变实现。

background-image: radial-gradient(circle, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
background-size: 92px 92px;
background-repeat: no-repeat;

鼠标监听方法:

tbody.addEventListener("mousemove", function(event) {
            var ev = event || window.event;
            ev.preventDefault();
            this.style["background-position"] = (ev.clientX - this.offsetLeft - 40) + "px " +
                (ev.clientY - this.offsetTop - 40) + "px";
        }, true);
        tbody.addEventListener("mouseout", function(event) {
            var ev = event || window.event;
            ev.preventDefault();
            this.style["background-position"] = "-92px -92px";
        }, true)

完整代码见:github地址

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值