使用CSS或Javascript从Github Gist列表中删除/(textnode)

问题描述 投票:2回答:1

我试图从Github Gists中的gists列表中删除用户名和/值,问题是没有类/ ids或/值可用的选择器。

enter image description here

这是HTML和Github Gists页面和JSFiddle的链接:

<div class="d-inline-block">
    <span>
        <a data-hovercard-type="user" data-hovercard-url="/hovercards?user_id=167012" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self"
            href="/hanachin">hanachin</a>
        /
        <a href="/hanachin/2060751fca3444922386879ac666541e">
            <strong class="css-truncate-target">file0.txt</strong>
        </a>
    </span>
    <div class="text-gray" style="font-size:11px;">
        Last active
        <time-ago datetime="2019-03-08T08:24:35Z">Mar 8, 2019</time-ago>
    </div>
    <span class="f6 text-gray">
        Ruby 2.7 ref:
        <a href="https://qiita.com/hanachin_/items/1aa1ba38a87dee91aed6" rel="nofollow">https://qiita.com/hanachin_/items/1aa1ba38a87dee91aed6</a>

    </span>
</div>

List of Github Gists

DEMO on JSFiddle

我可以使用以下代码删除图标和用户名:

[data-hovercard-type="user"] {
display:none;
}

[data-hovercard-type="user"] img {
display:none;
}

但/没有任何类,似乎是一个节点/ #textnode?我该如何访问?

javascript html css custom-data-attribute
1个回答
0
投票

据我所知,文本节点没有CSS选择器。但是要隐藏/,你可以将它的font-size设置为0px

所以CSS解决方案(尽管不是最好的,因为我们依赖于dom结构不改变)

.gist-snippet-meta .d-inline-block > span:first-of-type {
    font-size: 0px;
}

.gist-snippet-meta .d-inline-block > span:first-of-type > a:last-of-type {
    /* Reset font size back ot what it was before we set it to 0 on the parent */
    font-size: 14px;
}

另一种选择是使用Javascript,

这个问题是你需要等待DOM加载。因此,您的更改尚未应用。

此外,您仍然依赖文件名作为父容器中的最后一个锚元素,除非您使用Regex获取要点网址(在此处牺牲一些性能)或者您知道用户名

例如,用户名保持不变

Array.from(document.querySelector([data-hovercard-type="user"])).forEach( e => {
    var parent = e.parentElement;
    parent.innerHTML = parent.querySelector('a[href*="hanachin/"]').outerHTML;
});
© www.soinside.com 2019 - 2024. All rights reserved.