1
我有一個部分_dial_pad.html_erb正在被通過Ajax調用加載不止一次在相同的觀點,使用類似:如何確保我只在我的部分中加載JS文件一次?
$('#some_div').html("<%= escape_javascript(render(partial: 'dial_pad')) %>");
的dial_pad部分包括:
<%= stylesheet_link_tag 'dial_pad' %>
<%= javascript_include_tag "dial_pad" %>
<center>
<div id="main-wrapper" >
<section role="main">
<div class="dialPad compact">
<div class="dials">
<ol>
<li class="digits one">
<p><strong>1</strong></p>
</li>
<li class="digits two">
<p><strong>2</strong></p>
</li>
</ol>
</div>
</div>
</section>
<br/>
</div>
</center>
的dial_pad.js.coffee看起來像這樣:
jQuery ->
$(document).keydown (e) ->
key = String.fromCharCode(e.keyCode)
if key=='1'
alert("1")
if key=='2'
alert("2")
現在,當dial_pad部分加載dial_pad j也加載了。所以我最後按1,例如警報觸發兩次。
如何確保dial_pad.js只加載一次,而不是每當爲視圖添加部分時都加載?