2012-04-06 66 views
0

=== UPDATE ===更改CSS

如果我從模板中刪除the style="display: none;和下面推薦應用以下方法,當你點擊任何其他名單上的空集裝箱火災項目。還有什麼可以做的?

我有一個是在運行時動態使用jQuery和JSON(使用嵌入式HTML是一個模板)創建的UL列表。當用戶點擊列表項目(#navItem)時,我需要改變背景CSS樣式。我已經嘗試了月球下的所有內容,我可以從內聯類中想到.appentTo()等。下面我對硬編碼元素的工作很好,但似乎沒有任何工作與動態加載的內容。更令人困惑的是,li標籤中的元素中的類啓動...?

任何幫助,將不勝感激。以下是我的代碼片段。日Thnx。

HTML:

<div id="navScrollContainer" class="navContentPosition"> 
    <ul id="navContent"> 
    // Display as 'None' to prevent a empty containter from showing --> 
     <li id="navItem" class="ulFx" style="display: none;">//<-THIS NEEDS TO CHANGE ONCLICK!! 
      <a class="navA"> 
      <h1 class="navH1">.</h1> 
      <h2 class="navH2">.</h2> 
      <p class="navP">.</p> 
      <hr class="navHR" /> 
     </li> 
    </ul> 
</div> 
<script type="text/javascript"> 
    $('#navScrollContainer').on('click', '.ulFx', function() { 
     $(this).addClass("liFx"); 
    }); 
</script> 

這是數據注入到DOM以列表的功能:

function loadNav(url, container, appendE) { 
    $.getJSON(url, function(data) { 

     $.each(data.items, function() { 
      var newItem = $('#' + container).clone(); 
      // Now fill in the fields with the data 
        newItem.addClass('ulFx'); 
      newItem.find("h1").text(this.label); 
      newItem.find("h2").text(this.title); 
      newItem.find("p").text(this.description); 
      newItem.find("a").attr("href", this.gotoURL); 
      newItem.children().appendTo('#' + appendE); 
     }); 

     $('#navHeaderTitle').text(data.listTitle); 
     iniScroll('scrollNav', 'navScrollContainer'); 
     var target = data.targetKey; 
     // transition("#" + pageName, "show"); 
    }); 
}; 

需要發生(只對項目)的CSS當用戶點擊一個項目:

@-webkit-keyframes 
liBG {from { 
    background-color: transparent 
} 
50% { background-color: rgba(51,102,255,0.15); } 
to { 
    background-color: transparent 
} 
} 

.liFx { 
    -webkit-animation-name: liBG; 
    -webkit-animation-duration: 1s; 
    -webkit-animation-fill-mode: forwards; 
} 

給予利項目的類atributes:

.navH1 { 
    font-size: 18px; 
    color: #FFA500; 
    text-decoration: underline; 
    font-weight: bold; 
    margin-top: 8px; 
    margin-bottom: 8px; 
    margin-left: 15px; 
} 
.navH2 { 
    font-size: 16px; 
    color: #999999; 
    font-weight: bold; 
    margin-top: 5px; 
    margin-bottom: 5px; 
    margin-left: 25px; 
    font-weight: bold; 
} 
.navP { 
    color: #888; 
    font-size: 14px; 
    text-align: justify; 
    margin-top: 5px; 
    margin-bottom: 16px; 
    margin-left: 25px; 
    margin-right: 10px; 
} 
.navA { 
    text-decoration: none; 
} 
.navHR { 
    border: none; 
    background-color: #336; 
    height: 1px; 
} 
+0

哪裏是你的點擊監聽器? – Rick 2012-04-06 17:14:29

+0

獲取到'newItem.find(「a」)。attr(「href」,this.gotoURL);'從數據庫通過php到json。即:''gotoURL':「javascript:navClickListener('bodyContent',dns +'\/wiki \ /index.php \ /Airworthiness_Directive#content');' – CelticParser 2012-04-06 17:20:53

回答

0

我增加了一個DIV和addClass()方法到我的功能Jeff B's answer above。如果該類被硬編碼到標籤中,它不起作用。

<ul id="navContent"> 
    <li id="navItem" style="display: none;"> 
     <div>//ADDED THIS TAG TO EXCEPT THE CLASS 
      <a> 
       <h1>.</h1> 
       <h2>.</h2> 
       <p>.</p> 
       <hr/> 
      </a> 
     </div> 
    </li> 
</ul> 

在我的js文件:

$.each(data.items, function() { 
    var newItem = $('#' + container).clone(); 
    // Now fill in the fields with the data 
    newItem.find("div").addClass("ulFx");//ADDED THIS METHOD 
    newItem.find("h1").text(this.label); 
    newItem.find("h2").text(this.title); 
    newItem.find("p").text(this.description); 
    newItem.find("a").attr("href", this.gotoURL); 
    newItem.children().appendTo('#' + appendE); 
}); 
3

這會留意動態元素:

$(".liFx").live("click", function() { 
    $(this).addClass("liBG"); 
}); 
+5

'.live()'已被棄用, .on()'在最新版本的jQuery中。 – 2012-04-06 17:22:21

+2

「on」詳細信息:http://api.jquery.com/on – 2012-04-06 17:24:53

3

沒有看到你的點擊處理程序,我只能猜測。但是,通常當問題與動態內容相關並讓他們響應刺激時,問題在於你如何附加處理程序。

如果您使用.click().trigger('click'),處理程序將直接應用於您要調用這些功能的元素。這意味着如果元素當前不存在,他們將不會收到處理程序。

來解決這個問題的方法,是將事件偵聽器附加到會永遠存在,然後看該事件從動態子元素向上傳播的父元素。您可以通過查看event.target來手動執行此操作,但像往常一樣,jQuery使我們更容易。

這樣做的jQuery的現代方法是使用.on()documentation):

$('#someparent').on('click', '#childselector', function() { 
    // my handler code 
}); 

jQuery的再附着上#someparent處理程序,當它看到是針對#childselector一點擊,它觸發。

如果你想一類適用於#navContent一個孩子,#navContent會一直存在,這樣做:

$('#navContent').on('click', 'li', function() { 
    $(this).addClass("liFx"); 
}); 

如果#navContent是動態的一樣,只是走在DOM樹高。請注意,li的ID爲navItem。這聽起來很像一個類,而不是一個ID。如果您要擁有多個navItem,則它們不能全部具有相同的ID。這就是類是什麼:

<li class="navItem liFx" style="display: none;"> 
+0

@Sam Tyson我知道這是應該如何完成的,但有些原因並沒有引起我的注意。 ('click','.liFx',function(){$(this).addClass(「liFX」);}我嘗試了所有可以考慮的組合,現在我添加了$('#navContent')。 ()';'navContent',function(){$(this).addClass(「liFx」);'如果我上一個父'$('#navScrollContainer')。 );});」 ,它如預期的那樣;點亮了所有的項目 - 不是所選的項目。還有什麼我可能有錯? – CelticParser 2012-04-06 19:19:04

+0

@Sam Tyson我甚至嘗試添加'newItem.find(「li」)。addClass('liFx') ;'等我的loadNav函數 – CelticParser 2012-04-06 19:26:48

+0

@Andaero,你正在等待'liFx'被點擊,然後添加'liFx'類,這沒有任何意義,'click'後的選擇器是你想要的選擇器('click','li',function(){$(this).addClass(「liFX」);});' – 2012-04-06 20:49:01

0

我不知道問題出在哪裏,但你正在嘗試做的事情是這樣的:

$("#navlink").on('click', function() { 
    $("#yourselector").css("backgroundColor", "#ddd"); //change the color 
});