angular.js - 為什么給 Angular 指令綁定事件無法生效
問題描述
因為剛剛接觸 Angular,所以有些概念還很模糊,對于這個問題嘗試通過 Google 查找答案,但并未找到合適的解答,所以想在這里請教一下各位,這里是一個大概的代碼:
<p ng-repeat='item in list' class='need-another-js'></p><script> $(’.need-another-js’).click(function(){// do something })</script>
如果把 ng-repeat 去掉,JS 代碼的效果可以實現,但是加上 ng-repeat 后,效果就不存在,這里是因為 Angular 作用域的問題嗎?
問題解答
回答1:這和作用域沒有半毛錢關系,純粹是一種典型的jquery => angular的錯誤表現形式。
AngularJS的指令,作為一種“聲明式”的API,玩法和jquery那套“命令式”API有很大區別,你在混著用的時候,很容易出錯。
基本常識錯誤,id是用來表示元素唯一性的,可你用在了ng-repeat上,也就是說可能出現若干個元素的id都是need-another-js,這和jquery、angular都沒關系,純粹是html知識上的缺失
ng-repeat作為angular提供的指令,需要經過angular的compile、linking過程,導致,當你的$(’#need-another-js’).click在為#need-another-js元素注冊事件的時候,這個元素其實還沒有被angular生成到DOM中,這才是沒生效的關鍵。
單就你這個例子來講,可以做如下修改使之生效:
<p ng-repeat='item in list' class='need-another-js'></p>
不用id用class
<script> $(document).on(’click’, ’.need-another-js’, function(){// do something });</script>
雖然我不推薦這種寫法,但你既然選擇了'命令式'和聲明式API混用,想必有你的理由。
補充:
關于angular是如何工作的,我想對于剛入門的同學,看看官網這個介紹很有幫助:
文檔地址: concepts
回答2:<p ng-repeat='item in list' id='need-another-js'></p><!--ng-repeat生成了一系列id為need-another-js的DOM元素,而DOM元素的ID是不能重復的--><script> $(’#need-another-js’).click(function(){//可能在ng-repeat還未執行完成的時候便執行了 //需在ng-repeat執行完成時,設置onclick事件才有效// do something })</script>回答3:
angular有它支持的綁定事件 ng-click
你可以嘗試一下這樣寫
<p ng-repeat='item in list' ng-click='click()'></p><script> //省略其他控制器的寫法 $scope.click = function() { //do something }</script>回答4:
我學angular的時候,直接就從jq換成angular了,jq能做的angular都能做
回答5:ng-repeat是動態添加dom元素,你給動態添加的元素用click方法綁定事件是不會觸發的。如果你喜歡用jquery,就用leftstick提出的方法,但建議使用mumofa提出的angular方法
相關文章:
1. node.js - nodejs如何發送請求excel文件并下載2. docker-machine添加一個已有的docker主機問題3. 為什么我ping不通我的docker容器呢???4. golang - 用IDE看docker源碼時的小問題5. html5 - 使用angular中,圖片上傳功能中選擇多張圖片是怎么實現的?有什么好的思路嗎?6. android 如何實現如圖中的鍵盤上的公式及edittext的內容展示呢7. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?8. mysql - 詳細論述聯表查詢與分步查詢的優缺點9. mysql - 求SQL語句10. PHP注冊功能
