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

标签 javascript angularjs angularjs-directive

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

<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/

相关文章:

javascript - 是否有一种松散耦合的方式来从动态创建的 View / Controller 更新父指令,该 View / Controller 是父指令的子指令

javascript - jquery获取图片大小的方法

javascript - 如何使用angular-ui bootstrap在angularjs中实现服务器端分页。?

javascript - 在不提交表单的情况下使用 ngClick 触发自动完成

javascript - Angular/Angular 路由不起作用

angularjs - $locationChangeSuccess 触发四次

javascript - 在 JS 中隐藏/显示 DIV 不再有效 - 顺便说一下,潜在的冲突脚本

javascript - Angular 拦截器给出空白输出,没有错误

javascript - mdInkRipple 波纹整个 mdVirtualRepeat - Angular Material

javascript - 在 angularJS 中集成验证码的最佳方法