我有一个a
元素,它具有自己的href,并且效果很好。问题是,除了一个href
元素之外,我还想创建一个onClick
函数,但是当我这样做时,href
被忽略了:
<li><a href="#someSectionOfThePage" onClick={someFunction}>GO TO SECTION</a></li>
使用此语法,someFunction
运行,但是我没有被重定向到#someSectionOfThePage
。
答案 0 :(得分:2)
这应该可以解决问题:
<li onClick={someFunction}>
<a href="#someSectionOfThePage">GO TO SECTION</a>
</li>
当您单击<li>
时,它将执行功能...,而当您单击<a>
时,它将处理href
。由于您将单击此元素,因此两者将同时工作。
答案 1 :(得分:0)
标签中存在的href
由于onClick
事件而无法正常工作。单击元素后,它执行someFunction()
,而不是将您重定向到页面的该部分。您可以尝试添加
location.href = "#someSectionOfThePage"
到someFunction()
来完成href
的工作。
答案 2 :(得分:0)
您还可以尝试为click event
添加一个li
处理程序,并确保li
和定位标记a
采用相同的width
。
答案 3 :(得分:0)
尽管不建议这样做,但是如果您仍然想同时使用两者,那么就可以达到目的:
someFunction= ()=>{
window.location.href("#someSectionOfThePage");
//do your onClick stuff here
};
<li>
<span onClick={this.someFunction}>GO TO SECTION</span>
</li>
希望这会有所帮助!