angular.js - `ng-bind-html`中的`ng-click`指令不生效
問題描述
js代碼如下:
$scope.uploadInfo = $sce.trustAsHtml(’上傳成功!<a ng-click='’+'quitTo(’customer’)'+’'>點擊</a>跳轉到客戶列表界面’);//$scope.$apply();
html代碼如下:
<p class='modal-content'> <p ng-bind-html='uploadInfo'> </p></p>
在瀏覽器中看到的dom結構如下:
點擊圖中文字鏈接沒有任何響應,在“quitTo()”函數中設斷點發現沒有執行到。怎么才能讓這里生效呢?我試了$scope.$apply(),還試了$compile(),發現都沒有用。
問題解答
回答1:有別的方法,或能具體解釋其原理的話,希望可以和我分享這個問題雖然自己解決了,但感覺不是非常理解。用的是
var uploadInfo = ’上傳成功!<a ng-click='’+'quitTo(’customer’)'+’'>點擊</a>跳轉到客戶列表界面’;var ele = $compile(uploadInfo)($scope);angular.element(’.modal-body’).append(ele);
沒有用ng-bind-html和$sce.trustAsHtml()。
回答2:任何指令的生效都需要compile,這一步在app啟動的時候angular先幫你做了,但你插入的html是沒有經過compile這個步驟的,所以你手動compile下即可,之前自己寫指令,動態插入元素時遇到過類似情況,歡迎繼續交流。
相關文章:
1. node.js - nodejs+express+vue2. javascript - 我的站點貌似被別人克隆了, google 搜索特定文章,除了域名不一樣,其他的都一樣,如何解決?3. java - web端百度網盤的一個操作為什么要分兩次請求服務器, 有什么好處嗎4. 數據庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。5. javascript - 如何獲取未來元素的父元素在頁面中所有相同元素中是第幾個?6. python - 如何把152753這個字符串轉變成時間格式15:27:537. 使用mysql命令行連接遠程數據庫host跳轉8. javascript - onclick事件點擊不起作用9. javascript - webpack-dev-server和webpack沖突嗎10. python 字符串匹配問題

網公網安備