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]);
}
}

转载于:https://www.cnblogs.com/huoerheaven/p/9391703.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值