svg 图标只有点击 图标的边才会触发点击事件

近来开发时发现,svg 图标添加点击事件只有在点击 图标的边时才有效

经过查阅,解决办法有两个 ,在此记录一下

1. 设置css 

svg{

        pointer-events: none;

}

2. 在svg 图标 外层套一层 ,给外层添加点击事件 

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现这个功能,可以通过以下步骤: 1. 在盒子中添加一个图标,用来触发展开/收起操作; 2. 设置盒子的高度和 overflow 属性,使其固定高度并出现纵向滚动条; 3. 通过 CSS 动画控制盒子的展开/收起。 具体实现代码如下: ```jsx import React, { useState } from "react"; function Box() { const [isExpanded, setIsExpanded] = useState(false); const handleToggle = () => { setIsExpanded(!isExpanded); }; return ( <div style={{ height: isExpanded ? "auto" : "100px", overflowY: "auto", border: "1px solid #ccc", padding: "10px", position: "relative" }} > {isExpanded ? ( <> <p> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed suscipit, sapien non bibendum placerat, orci elit placerat nisi, vel ultrices massa ex in velit. Nam elit ligula, sodales eget malesuada quis, dapibus et purus. </p> <p> Suspendisse sed finibus urna. Aenean sollicitudin, mi et condimentum ornare, arcu risus tristique nunc, non egestas nisl massa vitae risus. Sed tincidunt lorem vel purus lobortis, vitae pharetra quam consequat. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia curae; Nunc at justo ullamcorper, tincidunt velit vel, consequat nulla. Morbi non tincidunt lacus. Aenean nec lectus vel arcu semper tincidunt sit amet a nunc. Donec posuere magna ac dui maximus consequat. Nulla sed risus euismod, commodo ante ac, bibendum arcu. </p> </> ) : null} <div style={{ position: "absolute", bottom: "10px", right: "10px" }} onClick={handleToggle} > {isExpanded ? ( <svg width="24" height="24" viewBox="0 0 24 24"> <path d="M19 13H5v-2h14v2z" /> </svg> ) : ( <svg width="24" height="24" viewBox="0 0 24 24"> <path d="M7 10l5 5 5-5z" /> </svg> )} </div> </div> ); } export default Box; ``` 在这个例子中,我们通过 useState hook 来控制盒子的展开/收起状态,点击图标触发 handleToggle 函数,通过修改 state 来改变盒子的高度。在盒子的样式中,我们设置了固定高度和 overflow 属性来出现纵向滚动条。最后,我们通过绝对定位把图标放在了盒子的右下角,并通过 CSS 控制其样式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值