本文主要介绍了angularjs实现自定义指令及指令配置项的方法,结合实例形式简单总结分析了angularjs自定义指令及指令配置项的实现技巧,需要的朋友可以参考下,希望能帮助到大家。
angularjs自定义指令有两种写法:
//第一种
angular.module('myapp',[])
.directive('zl1',zl1)
.controller('con1',['$scope',func1]);
function zl1(){
var directive={
restrict:'aec',
template:'this is the it-first directive',
};
return directive;
};
function func1($scope){
$scope.name="alice";
}
//第二种
angular.module('myapp',[]).directive('zl1',[ function(){
return {
restrict:'ae',
template:'thirective',
link:function($scope,elm,attr,controller){
console.log("这是link");
},
controller:function($scope,$element,$attrs){
console.log("这是con");
}
};
}]).controller('con1',['$scope',function($scope){
$scope.name="aliceqqq";
}]);
指令配置项
angular.module('myapp', []).directive('first', [ function(){
return {
// scope: false, // 默认值,共享父级作用域
// controller: function($scope, $element, $attrs, $transclude) {},
restrict: 'ae', // e = element, a = attribute, c = class, m = comment
template: 'first name:{{name}}',
};
}]).directive('second', [ function(){
return {
scope: true, // 继承父级作用域并创建指令自己的作用域
// controller: function($scope, $element, $attrs, $transclude) {},
restrict: 'ae', // e = element, a = attribute, c = class, m = comment
//当修改这里的name时,second会在自己的作用域中新建一个name变量,与父级作用域中的
// name相对独立,所以再修改父级中的name对second中的name就不会有影响了
template: 'second name:{{name}}',
};
}]).directive('third', [ function(){
return {
scope: {}, // 创建指令自己的独立作用域,与父级毫无关系
// controller: function($scope, $element, $attrs, $transclude) {},
restrict: 'ae', // e = element, a = attribute, c = class, m = comment
template: 'third name:{{name}}',
};
}])
.controller('directivecontroller', ['$scope', function($scope){
$scope.name="mike";
}]);
相关推荐:
vue-cli 自定义指令directive 添加验证滑块详解
怎样使用vue的自定义指令完成一个下拉菜单
关于angularjs的自定义指令directive的具体介绍
以上就是angularjs实现自定义指令方法详解的详细内容。