javascript - settimeout中傳入參數的問題
問題描述
<body> <p class='nav'><ul class='nav_level_1'> <li><a href='http://www.piao2010.com/wenda/4071.html#'>首頁</a></li> <li><a href='http://www.piao2010.com/wenda/4071.html#'>課程大廳</a><ul class='nav_level_2'> <li><p class='corn'></p></li> <li><a href='http://www.piao2010.com/wenda/4071.html#'>JavaScript</a></li> <li><a href='http://www.piao2010.com/wenda/4071.html#'>JQuery</a></li></ul> </li> <li><a href='http://www.piao2010.com/wenda/4071.html#'>學習中心</a></li> <li><a href='http://www.piao2010.com/wenda/4071.html#'>經典案例</a></li> <li><a href='http://www.piao2010.com/wenda/4071.html#'>關于我們</a></li></ul> </p> <script type='text/javascript'> window.onload = function(){var nav_level_1 = document.getElementsByClassName('nav_level_1')[0], lis_1 = nav_level_1.children; for(var i = 0;i < lis_1.length;i++){lis_1[i].onmouseover = function(){ var ul = this.getElementsByClassName('nav_level_2')[0]; addHeight(ul);} } } function addHeight(ul){var ul_height = ul.offsetHeight;ul_height++;if(ul_height <= 95){ ul.style.height = ul_height + 'px'; setTimeout('addHeight(’'+ul+'’)',10);}else{ return;} } </script></body>
用settimeout寫二級菜單的展開收縮,在settimeout中傳入一個帶有參數的函數,不知道怎么傳,視頻中是這樣寫的setTimeout('addHeight(’'+ul+'’)',10)但是不太正常,請問是什么原因?
問題解答
回答1:setTimeout(function () {addHeight(ul)},10);回答2:
setTimeout 這個函數第一個參數可以接受一個 函數 或者 一段代碼,如果是代碼,則將它放進eval執行。
你這里的寫法就是一段代碼的寫法,你檢查一下引號的書寫,是不是一一對應的寫的正確。或者換成下面的兩個寫法都應該可以正常工作
setTimeout(function () { addHeight(ul)}, 10);
setTimeout(addHeight, 10, ul)
相關文章:
1. 怎么在網頁中設置圖片進行左右滑動2. node.js - mysql如何通過knex查詢今天和七天內的匯總數據3. mysql 插入數值到特定的列一直失敗4. mysql 怎么做到update只更新一行數據?5. python - 在使用Pycharm時經常看到如下的樣式,小括號里紅色的部分是什么意思呢?6. javascript - 新浪微博網頁版的字數限制是怎么做的7. python2.7 - python 函數或者類 代碼的執行順序8. 360瀏覽器與IE瀏覽器有何區別???9. javascript - 用jsonp抓取qq音樂總是說回調函數沒有定義10. sublime可以用其他編譯器替換嗎?
