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

不要因为一时的失败和挫折,就忘记以往壮志满满说过要去的远方。人皆有爱生恶死之心,人皆为舍生取死之道。何也见善不明耳。

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

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

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

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

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

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

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

完成

以下是完整版本

app.controller('customersCtrl', function ($scope, $http,$compile) { 
$scope.test = function(){ 
  alert('test'); 
} 
 
// TODO 动态生成html中 ng-click无效 解决方法 $compile 是传进来的 
//下边这句话就是要写入页面中的内容,首先把你写入的内容赋值给html 
var html = "<a rel="nofollow noopener noreferrer" href='javascript:void(0);' ng-click='test()'></a>" 
  
 
//用$compile进行编译 
 
var $html = $compile(html)($scope); 
 
 
//添加到页面中,或者你任何想添加的位置。}); 
 
$("body").append($html); 

这样ng-click就可以触发function了

到此这篇关于详解angularJS动态生成的页面中ng-click无效解决办法就介绍到这了。要使理想的宫殿变成现实的宫殿,须透过埋头苦干,不声不响的劳动,一砖一瓦的建造。更多相关详解angularJS动态生成的页面中ng-click无效解决办法内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!

您可能有感兴趣的文章
JS获取鼠标点击时的位置

vue、nginx部署后刷新报404错误的解决方法

electron-builder配置项

VUE聊天页面自动滚动到底部

VUE CTRL+ENTER换行,ENTER发送消息