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. android - 使用百度sdk调用SDKInitializer.initialize(this)时报错?2. javascript - 最近用echarts做统计图时遇到两个问题!!3. 浅谈Vue使用Cascader级联选择器数据回显中的坑4. html5 - 用h5本地存储是否安全?5. 基于Spring MVC Java的配置无法正常工作控制台显示无错误,但我的jsp页面未显示6. javascript - webpack-dev-server和webpack冲突吗7. javascript - react热加载的一段代码8. android - 优酷的安卓及苹果app还在使用flash技术吗?9. 微信公众号在线生成二维码带参数怎么搞?10. myeclipse中修改了javaweb的web.xml文件,为什么有时候会自动重新部署生效,有时就不会自动呢?

网公网安备