亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何在AngularJS中動態添加指令?

如何在AngularJS中動態添加指令?

慕沐林林 2019-07-29 11:08:26
如何在AngularJS中動態添加指令?我有一個非常簡化的版本,我正在做的是解決問題。我有一個簡單的directive。每當您單擊一個元素時,它會添加另一個元素。但是,需要首先編譯它才能正確呈現它。我的研究引導我$compile。但是所有的例子都使用了一個復雜的結構,我真的不知道如何在這里應用。小提琴在這里:http://jsfiddle.net/paulocoelho/fBjbP/1/JS就在這里:var module = angular.module('testApp', [])     .directive('test', function () {     return {         restrict: 'E',         template: '<p>{{text}}</p>',         scope: {             text: '@text'         },         link:function(scope,element){             $( element ).click(function(){                 // TODO: This does not do what it's supposed to :(                 $(this).parent().append("<test text='n'></test>");             });         }     };});Josh David Miller的解決方案:http: //jsfiddle.net/paulocoelho/fBjbP/2/
查看完整描述

3 回答

?
慕桂英3389331

TA貢獻2036條經驗 獲得超8個贊

你有很多毫無意義的jQuery,但在這種情況下$ compile服務實際上非常簡單

.directive( 'test', function ( $compile ) {
  return {
    restrict: 'E',
    scope: { text: '@' },
    template: '<p ng-click="add()">{{text}}</p>',
    controller: function ( $scope, $element ) {
      $scope.add = function () {
        var el = $compile( "<test text='n'></test>" )( $scope );
        $element.parent().append( el );
      };
    }
  };});

你會注意到我也重構了你的指令,以便遵循一些最佳實踐。如果您對這些問題有任何疑問,請與我們聯系。


查看完整回答
反對 回復 2019-07-29
  • 3 回答
  • 0 關注
  • 981 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號