this.map.on('mouseenter', name, e => { const features = this.map.queryRenderedFeatures(e.point) this.map.getCanvas().style.cursor = 'pointer' const properties = features[0].properties const position = features[0].geometry.coordinates pointTooltip.setLngLat(position) .setHTML(`<div class = 'tooltip'> <span> ${properties.qlmc}</span> <span>${formatStake(properties.qlzxzh)}</span> </div>`) .addTo(this.map) }).on('mouseleave', name, e => { const remove = () => { this.map.getCanvas().style.cursor = 'grab' pointTooltip.remove() } remove() }) 优化这段代码
时间: 2024-02-14 11:25:54 浏览: 173
优化这段代码可以考虑以下几点:
1. 将匿名函数改为命名函数,提高代码的可读性和可维护性。
2. 将事件处理函数单独提取出来,以便复用。
3. 使用解构赋值简化代码。
4. 使用箭头函数简化代码。
下面是优化后的代码:
```javascript
// 定义事件处理函数
const handleMouseEnter = (e) => {
const { point } = e;
const features = this.map.queryRenderedFeatures(point);
this.map.getCanvas().style.cursor = 'pointer';
const { properties, geometry } = features[0];
const { coordinates } = geometry;
pointTooltip.setLngLat(coordinates)
.setHTML(`<div class = 'tooltip'>
<span>${properties.qlmc}</span>
<span>${formatStake(properties.qlzxzh)}</span>
</div>`)
.addTo(this.map);
};
const handleMouseLeave = () => {
this.map.getCanvas().style.cursor = 'grab';
pointTooltip.remove();
};
// 添加事件监听
this.map.on('mouseenter', name, handleMouseEnter)
.on('mouseleave', name, handleMouseLeave);
```
通过以上优化,代码更加清晰易读,也方便了后续的维护和修改。
阅读全文