luwenbangisme 2010-12-09 17:01
浏览 192
已采纳

如何做到结构与行为的分离

w3c标准要求我们做到结构与行为分离;在jsp里面我们用








/logic:iterate
/logic:notEmpty

来迭代数据,如果把a标签里面onclick方法分离出来,那么方法里面的参数将如何获取?

  • 写回答

1条回答 默认 最新

  • cyrilluce 2010-12-09 19:43
    关注

    html上只存数据,再用JS监听父容器,进行代理监听click事件,根据点击的节点来取数据。

    将数据存于data:id中(data为namespace,防止冲突)
    [code="html"]

    [/code]

    jQuery示例,这里简单的进行了代理,只监听父容器(因为事件会冒泡)
    [code="js"]
    var ct = $("dom_ct");
    ct.click(function(e){
    if($(e.target).is("a[data\:id]"){
    viewProduct(e.target.getAttribute("data:id");
    }
    });
    [/code]

    上面的代码不能处理a标签有子节点的情况,加强版:
    [code="js"]
    var ct = $("dom_ct");
    ct.click(function(e){
    var dom = e.target;
    while(dom && dom!==e.currentTarget){
    if($(dom).is("a[data\:id]")){
    console.log(dom.getAttribute("data:id"));
    break;
    }else{
    dom = dom.parentNode;
    }
    }
    });
    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 同一个网口一个电脑连接有网,另一个电脑连接没网
  • ¥15 问题重发,R语言:代码运行过程中出现如下警告,请求如何解决!
  • ¥15 神经网络模型一直不能上GPU
  • ¥15 苍穹外卖拦截器token为null
  • ¥15 pyqt怎么把滑块和输入框相互绑定,求解决!
  • ¥20 wpf datagrid单元闪烁效果失灵
  • ¥15 券商软件上市公司信息获取问题
  • ¥100 ensp启动设备蓝屏,代码clock_watchdog_timeout
  • ¥15 Android studio AVD启动不了
  • ¥15 陆空双模式无人机怎么做