首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >单击<li>列表只适用于第一个

单击<li>列表只适用于第一个
EN

Stack Overflow用户
提问于 2015-11-02 12:35:57
回答 3查看 42关注 0票数 0

我有几个li元素,我希望每个元素都是可点击的。这就是我所拥有的:

代码语言:javascript
复制
<li  id="stream-object" data-stream="val1">
<li  id="stream-object" data-stream="val2">
<li  id="stream-object" data-stream="val3">

和我的jquery

代码语言:javascript
复制
$("#stream-object").click(function(){
var stream_link=$(this).data("stream");
$("#main_stream").attr("data",stream_link);
});

但这只适用于第一个李。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-11-02 12:37:21

这是预期的行为,因为HTML中的必须是唯一的,您可以使用一个公共类然后使用Class Selector (“.class”)

选择具有给定类的所有元素。

HTML

代码语言:javascript
复制
<li class="stream-object" data-stream="val1">
<li class="stream-object" data-stream="val2">
<li class="stream-object" data-stream="val3">

脚本

代码语言:javascript
复制
$(".stream-object").click(function(){
    var stream_link=$(this).data("stream");
    $("#main_stream").attr("data",stream_link);
});
票数 5
EN

Stack Overflow用户

发布于 2015-11-02 12:37:28

ID (#) 必须是唯一的页面使用clasess (.)

代码语言:javascript
复制
<li class="stream-object" data-stream="val1">
<li class="stream-object" data-stream="val2">
<li class="stream-object" data-stream="val3">

$(".stream-object").click(function(){});
票数 4
EN

Stack Overflow用户

发布于 2015-11-02 12:38:20

身份应该是唯一的。而是使用类

代码语言:javascript
复制
$(".stream-object").click(function(){
  var stream_link=$(this).data("stream");
  $("#main_stream").attr("data",stream_link);
  alert( $(this).html()+' is clicked' );
});
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul>
  <li class="stream-object" data-stream="val1">Item 1</li>
  <li class="stream-object" data-stream="val2">Item 2</li>
  <li class="stream-object" data-stream="val3">Item 3</li>
</ul>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33477737

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档