angularJS动态生成的页面中,ng-click无效解决办法

本文介绍了一种在动态生成的AngularJS页面中实现交互的方法。通过使用$compile服务编译带有ng-click指令的HTML字符串,并将其插入DOM,使得动态创建的元素能够响应AngularJS事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天碰到了一个这样的需求,在自己写的动态的页面中,写入的AngularJS无效不能点击响应事件,以下给出代码以及解决方案

1.首先将我们要赋值给页面的数据new一下

[javascript]  view plain  copy
  1. var html = "<a href='javascript:void(0);' ng-click='test()'></a>"  


2.用$compile函数编译一下上边的内容

[javascript]  view plain  copy
  1. var $html = $compile(html)($scope);  


 

3.将编译好的内容插入到页面中

[javascript]  view plain  copy
  1. $("body").append($html);  


完成


以下是完整版本

[javascript]  view plain  copy
  1. app.controller('customersCtrl'function ($scope, $http,$compile) {  
  2. $scope.test = function(){  
  3.     alert('test');  
  4. }  
  5.   
  6. // TODO 动态生成html中 ng-click无效 解决方法 $compile 是传进来的  
  7. //下边这句话就是要写入页面中的内容,首先把你写入的内容赋值给html  
  8. var html = "<a href='javascript:void(0);' ng-click='test()'></a>"  
  9.    
  10.   
  11. //用$compile进行编译  
  12.   
  13. var $html = $compile(html)($scope);  
  14.   
  15.   
  16. //添加到页面中,或者你任何想添加的位置。});  
  17.   
  18. $("body").append($html);  
  19.   
  20.   
  21. 这样ng-click就可以触发function了  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值