SVG学习(五)

在svg.js中,给元素绑定事件,也和html中一样,"元素.事件名"就行,而且也支持click,mouseover等多种事件,例如

javascript 复制代码
element.click(function() {
  this.fill({ color: '#f06' })
})

其中的this就指向当前元素。不过要注意,svg本身是不支持scroll滚动的。

如果想移除事件,就将事件设置为null就行

csharp 复制代码
element.click(null)

对于触发事件,svg.js有两种方式,fire和dispatch,两者都可以传递第二个参数来传参,区别在于返回值。fire的返回值是当前元素,dispatch是事件event对象

监听事件和html中一样,使用on方法

less 复制代码
var click = function() {
  this.fill({ color: '#f06' })
}
element.on('click', click)
element.fire('click')
element.dispatch('click')

可以同时监听多个事件

csharp 复制代码
element.on(['click', 'mouseover'], handler)
element.on('click mouseover', handler)

也可以改变函数中this的指向

dart 复制代码
element.on('click', click, window)

事件体函数中也有event事件对象

取消绑定事件同样简单:

arduino 复制代码
element.off('click', click) 

或者取消绑定特定类型的事件监听器:

vbnet 复制代码
element.off('click') 

或者多个事件类型:

vbnet 复制代码
element.off(['click', 'mouseover'])
element.off('click mouseover') 

甚至可以取消绑定所有事件的监听器:

scss 复制代码
element.off()

有了上面这些,就可以自定义事件使用了

javascript 复制代码
element.on('myevent', function() {
  alert('ta-da!')
})
function whenSomethingHappens() {
  element.fire('myevent')
}

除此之外,svg.js也可以在其他元素上绑定事件

dart 复制代码
SVG.on(window, 'click', click)
SVG.off(window, 'click', click)
相关推荐
马可菠萝3 分钟前
从零开始,用 Tauri + Vue 3 打造轻量级桌面应用
前端
陆枫Larry4 分钟前
JavaScript 字符串处理实战:从 `startsWith` 到链式 `replace` 的避坑指南
前端
天蓝色的鱼鱼21 分钟前
你的项目真的需要SSR吗?还是只是你的简历需要?
前端·架构
恋猫de小郭1 小时前
移动端开发稳了?AI 目前还无法取代客户端开发,小红书的论文告诉你数据
前端·flutter·ai编程
文心快码BaiduComate1 小时前
百度云与光本位签署战略合作:用AI Agent 重构芯片研发流程
前端·人工智能·架构
闲云一鹤2 小时前
nginx 快速入门教程 - 写给前端的你
前端·nginx·前端工程化
QCY2 小时前
「完全理解」1 分钟实现自己的 Coding Agent
前端·agent·claude
一拳不是超人3 小时前
Electron主窗口弹框被WebContentView遮挡?独立WebContentView弹框方案详解!
前端·javascript·electron
anyup3 小时前
🔥2026最推荐的跨平台方案:H5/小程序/App/鸿蒙,一套代码搞定
前端·uni-app·harmonyos
雮尘3 小时前
如何在非 Claude IDE (TARE、 Cursor、Antigravity 等)下使用 Agent Skills
前端·agent·ai编程