AngularJS - 如何将带有内插数据的对象(动态创建)传递给自定义指令
AngularJS - how to pass object (created on the fly) with a interpolated data to a custom directive
我想创建一个自定义指令,我可以向其传递一个带有内插值的对象(动态创建)。
示例:
新创建的数组作为参数:
{userName: vm.data.name}
vm.data.name 应替换为控制器数据。
这是我的代码:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Custom directive</title>
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.4.1/angular.min.js"></script>
<script>
(function(angular) {
'use strict';
angular.module('testDirectiveApp', [])
.controller('testController', ['$scope', function($scope) {
var data = {
name: 'ABC'
}
var vm = this;
vm.data = data;
}])
.directive('customDirective', ['$interpolate', function($interpolate) {
return {
scope: {
customParam: '='
},
link: function(scope, element, attributes){
scope.$watch('customParam', function() {
console.log(attributes.customParam, $interpolate(attributes.customParam)(scope), scope.$eval(attributes.customParam));
});
}
};
}]);
})(window.angular);
</script>
</head>
<body ng-app="testDirectiveApp">
<div ng-controller="testController as vm">
Name: <input ng-model="vm.data.name"> <hr/>
<div custom-directive custom-param="{userName: vm.data.name}"></div>
<p>{{vm.data.name}}</p>
</div>
</body>
</html>
这可行吗?我做错了什么?
此致,
问题是您正在尝试使用 attributes
对象访问范围变量,而不是 scope
对象。
在您的指令中,将 attributes.customParam
更改为 scope.customParam
我想创建一个自定义指令,我可以向其传递一个带有内插值的对象(动态创建)。
示例:
新创建的数组作为参数:
{userName: vm.data.name}
vm.data.name 应替换为控制器数据。
这是我的代码:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Custom directive</title>
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.4.1/angular.min.js"></script>
<script>
(function(angular) {
'use strict';
angular.module('testDirectiveApp', [])
.controller('testController', ['$scope', function($scope) {
var data = {
name: 'ABC'
}
var vm = this;
vm.data = data;
}])
.directive('customDirective', ['$interpolate', function($interpolate) {
return {
scope: {
customParam: '='
},
link: function(scope, element, attributes){
scope.$watch('customParam', function() {
console.log(attributes.customParam, $interpolate(attributes.customParam)(scope), scope.$eval(attributes.customParam));
});
}
};
}]);
})(window.angular);
</script>
</head>
<body ng-app="testDirectiveApp">
<div ng-controller="testController as vm">
Name: <input ng-model="vm.data.name"> <hr/>
<div custom-directive custom-param="{userName: vm.data.name}"></div>
<p>{{vm.data.name}}</p>
</div>
</body>
</html>
这可行吗?我做错了什么?
此致,
问题是您正在尝试使用 attributes
对象访问范围变量,而不是 scope
对象。
在您的指令中,将 attributes.customParam
更改为 scope.customParam