jQuery clone()方法綁定事件

來源:互聯網
上載者:User

標籤:

先看如下代碼:

 1 (function ($) { 2  3     var div = $("<div></div>").css({width: "100px", height: "100px"}); 4     var colors = ["red", "blue", "yellow"]; 5     for (var c = 0; c < colors.length; c++) { 6         var perDiv = div.clone(); 7         perDiv.css({ 8             background: colors[c] 9         });10         perDiv.click(function () {11             console.log(colors[c]);12         });13         $("body").append(perDiv);14     }15 16 })($);

無論點擊那個div都是輸出 underfined

所以此代碼不能解決每個div點擊出現不同的事件。

改進代碼:

 1 (function ($) { 2  3     var div = $("<div></div>").css({width: "100px", height: "100px"}); 4     var colors = ["red", "blue", "yellow"]; 5     for (var c = 0; c < colors.length; c++) { 6         var perDiv = div.clone(); 7         perDiv.css({ 8             background: colors[c] 9         });10         perDiv.addClass("a"+c);11         $("body").append(perDiv);12     }13 14     for (var e=0;e<colors.length;e++){15         $(".a"+e).click(function () {16             console.log($(this));17         });18     }19 })($);

效果:

,每當點擊一個對應就輸出一個資訊。

總結:給每個元素添加個class或id 就行了╮(╯▽╰)╭

jQuery clone()方法綁定事件

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.