zoukankan      html  css  js  c++  java
  • js触发a标记的点击事件[转]

    JS 中触发 A 标签的点击事件
    2009年06月17日 星期三 11:59

    问题:有一个列表,每一个条目都是这篇文章的部分内容,类似这样:

    <div class="list">
    <div class="item">
    第一篇文章</div>
    <div class="item">
    第二篇文章</div>
    .....</div>

    而且在每个条目的div的右上角都有一个“评论”链接,点击就会展开所有的评论,并且显示评论框,这个链接的形式如下:

    <a class="comment-mod" href="#">评论</a>

    如果用户直接查看文章列表,那么所有的评论以及评论框都是不显示的,但是如果用户通过别的页面比如首页的个人动态直接定位到这篇日志,那么评论就应该全部显示。而列表页和查看单个条目的页面是同一个页面,这就要求我判断一下用户是否定位到该篇日志,如果是,就通过JS来触发 A 标签的点击事件。

    一开始我尝试了一些方法,想当然地以为 A 标签和按钮一样是有 onclick() 事件的,结果发现没有,后来从网上搜了一些资料之后,成功解决了这个问题^_^ 。解决办法是针对 IE 和 FF编写不同的逻辑,部分代码如下:

    var comment = document.getElementsByTagName('a')[0];
     
    if (document.all) {
     // For IE 
     
    comment.click();
    } else if (document.createEvent) {
       //FOR DOM2
     
    var ev = document.createEvent('MouseEvents');
     ev.initEvent('click', false, true);
     comment.dispatchEvent(ev);
    }

    上面的代码在IE6, IE7 和 FireFox 3 下通过测试。

    一点学习心得,记录在此。

    参考资料:http://ued.koubei.com/?p=400

    测试的时候发现代码在FireFox 2下不好使,仔细检查之后发现了问题,把 document.createEvent(’HTMLEvents’) 改成 document.createEvent(’MouseEvents‘);就好了。(刚写完的时候唯独没有测试FireFox 2,结果还真是有问题,看来那句话说的对:如果你觉得可能会出问题,那就一定会出问题。

  • 相关阅读:
    Web用户的身份验证及WebApi权限验证流程的设计和实现
    开源工作流引擎CCFlow 学习专区
    Jquery Ajax方法传值到action
    再谈Jquery Ajax方法传递到action
    Windows下安装GTK+
    Tex使用
    配置Texmaker中文支持
    软件推荐列表(Recommand Software)
    CAD操作
    Package inputenc Error: Unicode char u8: not set up for use with LaTeX.
  • 原文地址:https://www.cnblogs.com/aaa6818162/p/1597149.html
Copyright © 2011-2022 走看看