我想通過元素集合,試圖找到一個特定的元素,並將類應用到該元素。問題是,即使選擇器返回一個對象集合,並且輸入了應用該類的條件,但在查看源代碼時該類不適用。Jquery選擇器返回html元素
這是函數:
function HighlightNav() {
$('.quick-launch-nav').css('visibility', 'visible');
var navitems = $('a.topnav-item[href]');
$(navitems).each(function() {
var item = this;
var linkUrl = item.href;
var webUrl = IPC_siteUrl + IPC_webUrl;
if (webUrl.match('^' + linkUrl)) {
$(item).addClass('topnavselected');
var parent = $(item).parent('.topnav-item');
$(parent).addClass('topnavselected');
}
});
}
當我嘗試通過查看內部HTML調試它,它返回一個JavaScript函數,而不是我所期待的。
我在這裏做錯了什麼?
這是標記。僅供參考其SharePoint如此醜陋。
<td onmouseover="Menu_HoverStatic(this)" onmouseout="Menu_Unhover(this)" onkeyup="Menu_Key(this)" id="zz1_TopNavigationMenun0">
<table class="topnav-item zz1_TopNavigationMenu_4" cellpadding="0" cellspacing="0" border="0" width="100%">
<tr>
<td style="white-space:nowrap;">
<a class="zz1_TopNavigationMenu_1 topnav-item zz1_TopNavigationMenu_3"
href="http://webapp/en/about"
accesskey="1" style="border-style:none;font-size:1em;">About</a>
</td>
</tr>
</table>
</td>
當我嘗試做$(項目).html.toString(),這是我所得到的:
function(a){return f.access(this,function(a){var c=this[0]||{},d=0,e=this.length;if(a===b)return c.nodeType===1?c.innerHTML.replace(W,""):null;if(typeof a=="string"&&!ba.test(a)&&(f.support.leadingWhitespace||!X.test(a))&&!bg[(Z.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(Y,"<$1></$2>");try{for(;d<e;d++)c=this[d]||{},c.nodeType===1&&(f.cleanData(c.getElementsByTagName("*")),c.innerHTML=a);c=0}catch(g){}}c&&this.empty().append(a)},null,a,arguments.length)}"
你可以張貼標記過? – mattytommo
順便提一下,'navitems'已經是一個jQuery對象,你不需要再次創建'$(navitems)'。 – VisioN
@mattytommo我加了標記。 –