首页 >web前端 >js教程 >如何在 AngularJS 控制器之间有效地传递变量?

如何在 AngularJS 控制器之间有效地传递变量?

DDD
DDD原创
2024-12-02 01:32:14300浏览

How Can I Effectively Pass Variables Between AngularJS Controllers?

在 AngularJS 控制器之间传递变量

在 AngularJS 控制器之间传递变量是应用程序开发中的常见任务。一种方法是创建一个服务来跨控制器共享变量。

创建共享服务

angular.module('myApp', [])
    .service('sharedProperties', function () {
        var property = 'First';

        return {
            getProperty: function () {
                return property;
            },
            setProperty: function(value) {
                property = value;
            }
        };
    });

使用服务

在控制器中,注入共享service:

function Ctrl2($scope, sharedProperties) {
    $scope.prop2 = "Second";
    $scope.both = sharedProperties.getProperty() + $scope.prop2;
}

注意事项

对于跨控制器工作的绑定,最好绑定到对象的属性而不是基元类型。

// Avoid using primitive types
var property = 'First';

// Use objects
var property = { Property1: 'First' };

示例

请参阅[这个小提琴](https://jsfiddle.net/philipjohnson/34qhw/) 的示例,演示:

  • 绑定到共享的静态副本值
  • 绑定到随着值变化而更新 UI 的共享值

    • 绑定到函数
    • 绑定到对象的属性
    • 双向绑定到对象财产

以上是如何在 AngularJS 控制器之间有效地传递变量?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn