@H_404_1@我需要创建一个新的角度范围并将其附加到DOM元素.我正在修改第三方控件,所以我没有选择只使用指令.
@H_404_1@我需要做类似的事情:
@H_404_1@
... = thirdPartyCallbackfunction(domElement){
var myNewScope = $scope.$new(true);
myNewScope.title = 'Hello';
domElement.scope = myNewScope; //???
}
@H_404_1@此外,我尝试手动将ng-scope添加到DOM元素,但ng-inspector向我显示它没有创建新的子范围.
@H_404_1@
$(domElement).scope();
@H_404_1@尝试时给我根本范围.
@H_404_1@docs也不是很有帮助.最佳答案
你应该使用$compile服务.
@H_404_1@HTML:
@H_404_1@
@H_404_1@控制器:
@H_404_1@
angular.module("myApp",[]).controller("myCtrl",["$scope","$compile",function($scope,$compile){
$scope.number = 35;
var myFunc = function(){
var innerElem = angular.element(document.querySelector("#child"));
var innerScope = $scope.$new();
innerScope.myProp = 55;
var compileFn = $compile(innerElem);
compileFn(innerScope);
}
myFunc();
}]);
@H_404_1@$compile用于评估HTML片段或DOM元素(包装在jqLite对象中).例如,您可以使用一些内联绑定的html模板代替DOM元素:
var content =“< ul>< li ng-repeat ='city in cities'> {{city}}< / li>< / ul>”
var list = angular.element(content); //从上面的模板创建jqLite对象;
下一步是使用$compile服务对象,该对象是一个返回另一个函数的函数,该函数随后将用于生成内容.
var compileFn = $compile(list);
@H_404_1@获得编译功能后,调用它将范围对象作为即将进行的评估的上下文传递,基本上将元素与范围相关联.
compileFn(范围);
现在模板中包含的绑定/表达式将使用您传递的范围进行评估并更新jqLite对象(列表),但是没有返回值,因此在这种情况下您必须手动将更新的列表对象添加到DOM .希望这能澄清一下服务.