如何在不对控制器进行dom操作的情况下将一些角度元素附加到div?

abh*_*nav 5 angularjs

有一个div有一些id说mainDiv.然后有三个按钮.单击每个按钮会向mainDiv添加具有不同指令的不同角元素.

<div id="mainDiv"></div>
<button ng-click="appendSomeElement1ToMainDiv()"></button>
<button ng-click="appendSomeElement2ToMainDiv()"></button>
<button ng-click="appendSomeElement3ToMainDiv()"></button>
Run Code Online (Sandbox Code Playgroud)

如何在不使用控制器中的dom操作的情况下实现此目的.它太诱人了

$scope.appendSomeElement1ToMainDiv = function () {
  var element1 = angular.element("<p>I am a new element</p>");
  $("#mainDiv").append(element1);
};
Run Code Online (Sandbox Code Playgroud)

Bet*_*aba 7

指令是您正在寻找的.你可以这样做:

myApp.directive('mainArea', function() {
    return {
        restrict: "E",
        template: "<div>"+
            "<div id='mainDiv'> </div>" +
            "<button data-ng-click='append()'>Add</button>" +
        "</div>",
        controller: function($scope, $element, $attrs) {
            $scope.append = function() {
                var p = angular.element("<p />");
                p.text("Appended");
                $element.find("div").append(p);
            }
        }
    }
});
Run Code Online (Sandbox Code Playgroud)

在你的HMTL中:

<main-area></main-area>
Run Code Online (Sandbox Code Playgroud)

工作小提琴

如果你的元素是一个指令,你应该看看 $compile