javascript - settimeout中傳入參數的問題
問題描述
<body> <p class='nav'><ul class='nav_level_1'> <li><a href='http://www.aoyou183.cn/wenda/4071.html#'>首頁</a></li> <li><a href='http://www.aoyou183.cn/wenda/4071.html#'>課程大廳</a><ul class='nav_level_2'> <li><p class='corn'></p></li> <li><a href='http://www.aoyou183.cn/wenda/4071.html#'>JavaScript</a></li> <li><a href='http://www.aoyou183.cn/wenda/4071.html#'>JQuery</a></li></ul> </li> <li><a href='http://www.aoyou183.cn/wenda/4071.html#'>學習中心</a></li> <li><a href='http://www.aoyou183.cn/wenda/4071.html#'>經典案例</a></li> <li><a href='http://www.aoyou183.cn/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. mysql優化 - mysql count(id)查詢速度如何優化?2. angular.js - 不適用其他構建工具,怎么搭建angular1項目3. mysql主從 - 請教下mysql 主動-被動模式的雙主配置 和 主從配置在應用上有什么區別?4. python - django 里自定義的 login 方法,如何使用 login_required()5. 主從備份 - 跪求mysql 高可用主從方案6. java8中,邏輯與 & 符號用在接口類上代表什么意思7. python如何不改動文件的情況下修改文件的 修改日期8. angular.js - angular-ui-bootstrap 報錯無法使用?9. node.js - node_moduls太多了10. python - 關于ACK標志位的TCP端口掃描的疑惑?
