angularJS動態生成的頁面中,ng-click無效解決辦法

今天碰到了一個這樣的需求,在自己寫的動態的頁面中,寫入的angularJS無效不能點擊響應事件,以下給出代碼以及解決方案

1.首先將我們要賦值給頁面的數據new一下

var html = "<a href='javascript:void(0);' ng-click='test()'></a>"

2.用$compile函數編譯一下上邊的內容

var $html = $compile(html)($scope);

3.將編譯好的內容插入到頁面中

$("body").append($html);

完成

以下是完整版本

  1. app.controller('customersCtrl', function ($scope, $http,$compile) {

  2. $scope.test = function(){

  3. alert('test');

  4. }


  5. // TODO 動態生成html中 ng-click無效 解決方法 $compile 是傳進來的

  6. //下邊這句話就是要寫入頁面中的內容,首先把你寫入的內容賦值給html

  7. var html = "<a href='javascript:void(0);' ng-click='test()'></a>"



  8. //用$compile進行編譯


  9. var $html = $compile(html)($scope);



  10. //添加到頁面中,或者你任何想添加的位置。});


  11. $("body").append($html);



  12. 這樣ng-click就可以觸發function



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章