Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/474.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何使用AngularJS对窗口大小的变化作出反应?_Javascript_Angularjs - Fatal编程技术网

Javascript 如何使用AngularJS对窗口大小的变化作出反应?

Javascript 如何使用AngularJS对窗口大小的变化作出反应?,javascript,angularjs,Javascript,Angularjs,我将此作为观察窗口大小调整事件的一种方法。然而,它的工作非常缓慢。如果有人知道其他简单且不涉及复杂指令的方法,是否可以提供建议。如果我的方式是一个好的方式,我也会很感激任何建议 $scope.$watch(($scope) => { $scope.isLarge = $window.innerWidth > 650 ? true : false; angular.element($window).on('resize', () => { $sco

我将此作为观察窗口大小调整事件的一种方法。然而,它的工作非常缓慢。如果有人知道其他简单且不涉及复杂指令的方法,是否可以提供建议。如果我的方式是一个好的方式,我也会很感激任何建议

 $scope.$watch(($scope) => {
    $scope.isLarge = $window.innerWidth > 650 ? true : false;
    angular.element($window).on('resize', () => {
       $scope.$digest();
    });
    console.log($scope.isLarge);
 });
工作小提琴:

HTML


谢谢你的建议,但你能告诉我,如果没有指令,这将如何工作。有这么多台词对我来说太过分了。我正在寻找最简单的解决方案。你能不能也评论一下我的代码,让我知道这样做是好是坏?谢谢
<div ng-app="miniapp" ng-controller="AppController" ng-style="style()" resize>window.height: {{windowHeight}}
    <br />window.width: {{windowWidth}}
    <br />
</div>
var app = angular.module('miniapp', []);

function AppController($scope) {
    /* Logic goes here */
}

app.directive('resize', function ($window) {
    return function (scope, element) {
        var w = angular.element($window);
        scope.getWindowDimensions = function () {
            return {
                'h': w.height(),
                'w': w.width()
            };
        };
        scope.$watch(scope.getWindowDimensions, function (newValue, oldValue) {
            scope.windowHeight = newValue.h;
            scope.windowWidth = newValue.w;

            scope.style = function () {
                return {
                    'height': (newValue.h - 100) + 'px',
                    'width': (newValue.w - 100) + 'px'
                };
            };

        }, true);

        w.bind('resize', function () {
            scope.$apply();
        });
    }
})