js 重写a标签的href属性和onclick事件

Posted 青春给了义务教育

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 重写a标签的href属性和onclick事件相关的知识,希望对你有一定的参考价值。

适应场景:假如移动端拨打电话,需要给a标签添加href属性,但是由于需求,需要链接跳转的同时给a标签添加onclick事件,如果不做任何处理的话,默认执行点击事件,而不会跳转href属性的链接。

怎么解决:重写a标签的href属性和onclick事件

//这段代码可放入点击事件里

(function(){

this.fnCancel();
var _event_list = {};
// 找到页面上所有的a标签
var links = document.getElementsByTagName("a")[0];
// 保存click属性的值
var _click = links.getAttribute("onclick");
// 保存href属性的值
var _href = links.getAttribute("href");
if (_click != null) {
// 给onclick属性重新设值
links.setAttribute("onclick", "eval_a_click_event(‘a‘)");
}
if (_href != null) {
// 给href属性重新设值
links.setAttribute("href", "javascript:eval_a_href_event(‘a‘)");
}
_event_list["a"] = [links, _href, _click];

})()

 

function eval_a_href_event(id) {
var link = _event_list[id];
if (link != null && link[1] != null) {
// 拿到href属性的值
alert(link[1]);
// 将href属性值重新赋回原来的值
link[0].setAttribute("href", link[1]);
// 移除单击事件
link[0].removeAttribute("onclick");
// 模拟单击事件
link[0][0].click();
// 重写href属性的值
link[0].setAttribute("href", "javascript:eval_a_href_event(‘" + id + "‘)");
// 如果有单击事件,重新加上
if (link[2] != null) {
link[0].setAttribute("onclick", link[2]);
}
}
}
function eval_a_click_event(id) {
var link = _event_list[id];
if (link != null && link[2] != null) {
// 拿到单击事件的方法
alert(link[2]);
// 执行单击事件
eval(link[2]);
}
}

以上是关于js 重写a标签的href属性和onclick事件的主要内容,如果未能解决你的问题,请参考以下文章

HTML中在a标签中添加onclick事件

关于A标签使用onclick事件的疑问

实现a标签中的各种点击(onclick)事件的方法

JS a标签 onClick问题

js中怎样获取鼠标当前点击的标签的值

在标签内反应 JS onClick 事件