🖲️一行代码实现鼠标换肤

前言

在上网冲浪的时候,经常可以看到有一些网站,一进去 鼠标指针就变成一些动态小人,或者自定义的样式。

像下面这样

那么这是实现的呢?

很简单,通过csscursor属性实现的。

cursor属性的介绍

  • cursor CSS 属性设置光标的类型(如果有),在鼠标指针悬停在元素上时显示相应样式。

平常开发中,肯定有设置过

css 复制代码
cursor:pointer;

​ 让鼠标放到按钮上面的时候,指针变成这种样式。

​ 但是这个属性除了直接设置关键字来修改样式,还支持引入url的方式来修改鼠标样式。

用法

语法如下:

css 复制代码
// cursor: url(xxx), [关键字];
cursor: url('./img/指针.png'), pointer;

效果如下:

上面这句代码中cursor: url('./img/指针.png'), pointer;, url 后面一定要再设置一个默认值,要是图片加载失败,就会使用下一个样式

不设置的话,就会属性值无效

支持的类型

类型 是否支持
png ✔️
jpg ✔️
gif ✖️
wepb ✔️
svg ✔️
cur ✔️

gif类型:引进去之后,不会动,只会变成静态的图片

cur:是静态光标文件,平常电脑的鼠标光标就是这种文件类型

完整代码

html 复制代码
<!DOCTYPE html>
<html lang="zh-cn">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>网页鼠标换肤</title>
    <style>
      html,
      body {
        width: 100%;
        height: 100%;
      }
    </style>
  </head>
  <body>
    <div class="btns">
      <button onclick="mousePeeling('./img/指针.png')">png</button>
      <button onclick="mousePeeling('./img/指针.svg')">svg</button>
      <button onclick="mousePeeling('./img/鼠标.jpg')">jpg</button>
      <button onclick="mousePeeling('./img/波奇.webp')">webp</button>
      <button onclick="mousePeeling('./img/正常选择.cur')">cur</button>
    </div>
    <script>
      function mousePeeling(url) {
        const body = document.body
        body.style.cursor = `url(${url}), pointer`
      }
    </script>
  </body>
</html>

这里我写了一个demo,来演示效果

效果如下

结尾

这是效果的实现非常简单,主要就是cursor属性的应用。

有几个要注意的地方

  • 图片的尺寸最大不超过32*32,超过之后,图片加载不出来
  • url引入图片后,结尾一定要设置一个默认的光标样式。
相关推荐
dorisrv19 小时前
优雅的React表单状态管理
前端
蓝瑟20 小时前
告别重复造轮子!业务组件多场景复用实战指南
前端·javascript·设计模式
dorisrv20 小时前
高性能的懒加载与无限滚动实现
前端
韭菜炒大葱20 小时前
别等了!用 Vue 3 让 AI 边想边说,字字蹦到你脸上
前端·vue.js·aigc
StarkCoder20 小时前
求求你,别在 Swift 协程开头写 guard let self = self 了!
前端
清妍_20 小时前
一文详解 Taro / 小程序 IntersectionObserver 参数
前端
电商API大数据接口开发Cris20 小时前
构建异步任务队列:高效批量化获取淘宝关键词搜索结果的实践
前端·数据挖掘·api
符方昊20 小时前
如何实现一个MCP服务器
前端
喝咖啡的女孩20 小时前
React useState 解读
前端
渴望成为python大神的前端小菜鸟21 小时前
浏览器及其他 面试题
前端·javascript·ajax·面试题·浏览器