Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/392.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 我是否正确使用了“this”?jQuery_Javascript_Jquery - Fatal编程技术网

Javascript 我是否正确使用了“this”?jQuery

Javascript 我是否正确使用了“this”?jQuery,javascript,jquery,Javascript,Jquery,我正在处理一个点击事件——它隐藏了任何与点击的用户值不同的用户。这是相关HTML的一个片段 <div class="main"> <section class="tweets"> <div class="tweet"> <p class="time">Sun Mar 15 2020 20:04:53 GMT-0700 (Pacific Daylight Time)</p>

我正在处理一个点击事件——它隐藏了任何与点击的用户值不同的用户。这是相关HTML的一个片段

<div class="main">
        <section class="tweets">
        <div class="tweet">
           <p class="time">Sun Mar 15 2020 20:04:53 GMT-0700 (Pacific Daylight Time)</p>
           <p class="users" data="sharksforcheap">@sharksforcheap: </p>
           <p class="message">last night i formulated a life #sxsw</p></div>
然而,我显然想让它为我点击的任何用户工作,因为为每个用户硬编码是不可行的。所以我创建了一个名为user的var,并将其引用到这个变量,它应该保存我的用户的数据。然而,这不起作用

     $('.tweets').on('click', '.users', function(){

      var user = $(this).data('users');
      $('.tweet').not(':contains('+ user + ')').hide(); 
    });

在这种情况下,我是否错误地使用了此属性?

这就是您需要指定data users属性以获取其值的方式。datausers:


谢谢你,伊戈尔。我感谢你在这里和我的另一个帖子中的帮助。如果我理解正确,关键字数据是否链接?当我添加数据用户时,是否需要在其中包含数据?或者我可以简单地把它放在users=sharksforcheap上。@newatlearning这必须是我展示的-data users=sharksforcheap。我想我很困惑。所以数据-必须链接到我调用的任何东西来保存我的元素值?@newatlearning这我不理解链接这个词。数据-。。。是HTML规范的一部分,jQuery让我们使用.data“…”函数获得这样的属性值。我想这对我来说是正确的。通过链接,我的意思是当调用.data“…”时,它将查找括号内调用的内容,但HTML代码需要包含数据。我原以为.data是一个函数,但在我看来它需要一个数据标识符,你需要定义这样的东西

@sharksforcheap:

     $('.tweets').on('click', '.users', function(){

      var user = $(this).data('users');
      $('.tweet').not(':contains('+ user + ')').hide(); 
    });
<p class="users" data-users="sharksforcheap">@sharksforcheap: </p>
$('.tweet').not($(this).closest('.tweet')).hide();