首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >窗口位置散列等于数据属性,然后触发数据属性。

窗口位置散列等于数据属性,然后触发数据属性。
EN

Stack Overflow用户
提问于 2015-10-12 15:30:58
回答 2查看 1.1K关注 0票数 1

在获取散列等于数据属性时,有一点被困住了。因此,如果url.com/#house-2,那么它将触发对测试2的点击。

代码语言:javascript
复制
<ul class="list">
    <li> 
<a  data-loc="house" href="#">test</a>        
    </li>
<li>
<a  data-loc="house-2" href="#">test2</a>
</li>
    <li>
<a  data-loc="house-3" href="#">test3</a>
</li>
</ul>

<script>
$(window).load(function() {

if (window.location.hash === data('loc')) {         
      setTimeout(function() {
        $('this').trigger('click');
    },1);           

  } 
 });

</script>
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-10-12 15:42:18

您可以使用attribute equals来选择目标a元素,并像这样触发.click()

代码语言:javascript
复制
$('.list a[data-loc="' + window.location.hash.replace('#', '') + '"]').trigger('click');

如果你的HTML包含那些data-loc属性,这是可行的。但是,如果数据是通过jQuery .data()函数添加的,则无法工作。

票数 1
EN

Stack Overflow用户

发布于 2015-10-12 15:47:42

可以使用filter()通过data-loc属性查找所需的元素。试试这个:

代码语言:javascript
复制
var fragment = window.location.hash;
if (fragment) {
    fragment = fragment.substr(1);
    $('.list a').filter(function() {
        return $(this).data('loc') == fragment;
    }).click(); 
} 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33084866

复制
相关文章

相似问题

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