gpt4 book ai didi

javascript - 如何在自定义指令中使用 ngChange

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:24:23 24 4
gpt4 key购买 nike

我想为切换按钮创建指令,我有代码要放入指令中:

<div class="toggle-button" ng-class="{true: toggleTrue === true, false: toggleTrue === false}">
<button class="true" ng-click="toggleTrue = true">Y</button><button class="false" ng-click="toggleTrue = false">N</button>
</div>

(我只处理风格变化,这就是为什么我只有类变化)

我想要这样的东西:

<toogle ng-change="SomeFunction()" ng-model="someValue" />

如何在指令中使用 ng-change?我应该只解析 attr 还是使用 scope 属性,或者是否有类似 ngModel 的代码需要与 ngChange 一起使用。

最佳答案

通过反复尝试,我找到了适用于 ngModel 和 ngChange 的代码:

return {
restrict: 'E',
require: 'ngModel',
scope: {},
template: '<div class="toggle-button" ng-class="{true: toggleValue === true, false: toggleValue === false}">'+
'<button class="true" ng-click="toggle(true)">Y</button>'+
'<button class="false" ng-click="toggle(false)">N</button>'+
'</div>',
link: function(scope, element, attrs, ngModel) {
ngModel.$viewChangeListeners.push(function() {
scope.$eval(attrs.ngChange);
});
ngModel.$render = function() {
scope.toggleValue = ngModel.$modelValue;
};
scope.toggle = function(toggle) {
scope.toggleValue = toggle;
ngModel.$setViewValue(toggle);
};
}
};

由于未知原因 scope: true 不起作用(如果我将 $scope.toggle 变量用作模型,它会尝试执行该 bool 值而不是函数)

关于javascript - 如何在自定义指令中使用 ngChange,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24286380/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com