angular.js - `ng-bind-html`中的`ng-click`指令不生效
問題描述
js代碼如下:
$scope.uploadInfo = $sce.trustAsHtml(’上傳成功!<a ng-click='’+'quitTo(’customer’)'+’'>點(diǎn)擊</a>跳轉(zhuǎn)到客戶列表界面’);//$scope.$apply();
html代碼如下:
<p class='modal-content'> <p ng-bind-html='uploadInfo'> </p></p>
在瀏覽器中看到的dom結(jié)構(gòu)如下:
點(diǎn)擊圖中文字鏈接沒有任何響應(yīng),在“quitTo()”函數(shù)中設(shè)斷點(diǎn)發(fā)現(xiàn)沒有執(zhí)行到。怎么才能讓這里生效呢?我試了$scope.$apply(),還試了$compile(),發(fā)現(xiàn)都沒有用。
問題解答
回答1:有別的方法,或能具體解釋其原理的話,希望可以和我分享這個(gè)問題雖然自己解決了,但感覺不是非常理解。用的是
var uploadInfo = ’上傳成功!<a ng-click='’+'quitTo(’customer’)'+’'>點(diǎn)擊</a>跳轉(zhuǎn)到客戶列表界面’;var ele = $compile(uploadInfo)($scope);angular.element(’.modal-body’).append(ele);
沒有用ng-bind-html和$sce.trustAsHtml()。
回答2:任何指令的生效都需要compile,這一步在app啟動(dòng)的時(shí)候angular先幫你做了,但你插入的html是沒有經(jīng)過compile這個(gè)步驟的,所以你手動(dòng)compile下即可,之前自己寫指令,動(dòng)態(tài)插入元素時(shí)遇到過類似情況,歡迎繼續(xù)交流。
相關(guān)文章:
1. android - Genymotion 微信閃退 not find plugin.location_google.GoogleProxyUI2. mac里的docker如何命令行開啟呢?3. html5 - 微信瀏覽器視頻播放失敗4. javascript - 單個(gè)控件多個(gè)字段搜索5. android webview返回自動(dòng)刷新6. docker綁定了nginx端口 外部訪問不到7. html - 特殊樣式按鈕 點(diǎn)擊按下去要有凹下和彈起的效果8. objective-c - iOS開發(fā)使用什么對(duì)html進(jìn)行代碼高亮9. angular.js - 關(guān)于ng-model和ng-bind的疑問10. javascript - npm安裝報(bào)錯(cuò) 系統(tǒng)w7 求大神解答
