我有以下
javascript代码将上传者名称放在上传日期之前,并在youtube搜索结果中查看计数.
function hasClass(element, cls) {
return (' ' + element.className + ' ').indexOf(' ' + cls + ' ') > -1;
}
var elems = document.getElementsByClassName('yt-lockup-meta-info');
var elemss = document.getElementsByClassName('yt-uix-sessionlink g-hovercard spf-link');
var elemsss = 1;
var elemssss = 0;
var myElem = document.getElementById('sb-button-notify');
if (myElem == null) elemsss = 0; // these two lines are here to skip the additional element
// that is only there if you are logged in
for (var i = 0; i < elems.length; ++i) {
if (hasClass(elemss[i+elemsss],'yt-uix-tile-link'))
{elemssss=elemssss+1;elemsss=elemsss+3;alert('damn');}
elems[i+elemssss].insertBefore(elemss[i+elemsss],elems[i+elemssss].firstChild);}
而不是hasClass函数,我如何检查多类元素的整个类属性?这不起作用:
element.className=='yt-uix-sessionlink yt-uix-tile-link
yt-ui-ellipsis yt-ui-ellipsis-2 g-hovercard spf-link'
我只需要检查类,因此代码可以跳过具有特定类的元素.更好的解决方案是document.getElementsByClassName的替代方案,它只能获取具有完全给定类的元素,并忽略具有MORE类的元素.
最佳答案
element.classList
它会返回元素上存在的所有类的数组
比如[“site-icon”,“favicon”,“favicon-stackoverflow”],那么通过使用普通的javascript,你可以实现自己的hasClass功能.
所以你的hasClass函数变成了
function hasClass(element, cls){
return element.classList.contains(cls);
}