从三个选择中检索值

时间:2015-01-09 03:58:35

标签: javascript angularjs select ng-options

我是AngularJS的新手,我一直在使用角度来集成php应用程序。 最近我试图从三个选择中获取值。

我在plunker编辑器上创建了两个文件作为示例 http://plnkr.co/edit/CA2D5RDvZeBQLnMUXFOH?p=preview

选择如下:

<body ng-app="MyForm">         

<!-- comment -->
        <div ng-controller="programsController">
        <select name="program" id="program" ng-model="program"
        ng-options="prog.name for prog in programs">
        </select>
        program.name {{program.name}}
        selected_program {{selected_program}}
        </div>

<!-- comment -->
        <div ng-controller="periodsController">
        <select name="period" id="period" ng-model="period"
        ng-options="period.name for period in periods">
        </select>
        </div>

<!-- comment -->
        <div ng-controller="teacherController">
        <select name="teacher" id="teacher" ng-model="teacher"
        ng-options="teacher.name for teacher in teachers">
        </select>
        </div>

        <button ng-click="vals()">Click</button>

    </div>

MyForm是应用程序的主要模块

angular.module('MyForm',['Programs','Periods','Teachers'])
.factory('myFactory', function() {
    console.log('Factory loaded');
    var course = {
        program : 'no set',
        setValues : function (program){
            course.program=program;
            //course.period=period;
            //course.teacher=teacher;
        },
        sayHello : function(){
            alert('hello');
        }
    }
    //console.log(course);
    return course;
})

.controller('mainController',['$scope','myFactory',function($scope,myFactory){

    $scope.vals = function(){
        //myFactory.setValues(myFactory.program);
//myFactory.sayHello();

        alert('The values are:' +
            '\nProgram: ' + myFactory.program +
            '\nProgram: ' + myFactory.period +
            '\nProgram: ' + myFactory.teacher);
    }
}]) ;

填充选择的模块

angular.module('Programs',[])
    .factory('proFactory',function(){
        var selected_program = '0';
        console.log('From proFactory');
    })

    .controller('programsController',function($scope,myFactory){
        $scope.programs=[
        {ID:1 , name:'HTML'},
        {ID:2 , name: 'AngularJS'}
        ];

        $scope.program = $scope.programs[0];
        //myFactory.setValues($scope.program.ID);
});

angular.module('Periods',[])
    .controller('periodsController',function($scope){
    $scope.periods=[
        {ID:1 , name:'Jan-Feb'},
        {ID:2 , name: 'Mar-Apr'}
        ];
    $scope.period = $scope.periods[0];
});

angular.module('Teachers',[])
    .controller('teacherController',function($scope){
    $scope.teachers=[
        {ID:1 , name:'Mark Smith'},
        {ID:2 , name: 'Joe Cliff'}
        ];
    $scope.teacher = $scope.teachers[0];
});

我试图获取三个选择的值,以便将数据发送到另一个脚本并在之前的警报中显示它们,但我无法得到它。

我已经读过,在控制器之间共享数据是创建提供者所必需的,在这种情况下我使用了工厂。

工厂有一个带有三个变量的对象,程序,句点和教师(最后两个被评论),两个函数setValues用于分配数据,而'ofayHello'用于测试工厂。

我评论了一个使用工厂sayHello函数的代码行,因此可以访问工厂。

html中的按钮有ng-click=vals(),该函数位于mainController的$ scope中,当我点击按钮时,我假装分配选择的值并显示它们。

我尝试通过myFactory.setValues(myFactory.program);分配值,并且这样myFactory.setValues($scope.program); $scope.program也在programsController的范围内

对此有任何评论或想法。 在此先感谢!!!!

2 个答案:

答案 0 :(得分:0)

你需要三个控制器吗? 三个控制器是不必要的麻烦,你只需要一个控制器来包含所有三个选择

这样您就可以访问同一范围内的所有三个值并将它们传递给工厂。我建议在一个范围内定义所有变量(句号,教师,程序)。

for ex

<body ng-app="MyForm">
    <div ng-controller="mainController">
        <select name="program" id="program" ng-model="program"
         ng-options="prog.name for prog in programs">
        </select>
        program.name {{program.name}}
        selected_program {{selected_program}}


        <select name="period" id="period" ng-model="period"
         ng-options="period.name for period in periods">
        </select>

        <select name="teacher" id="teacher" ng-model="teacher"
         ng-options="teacher.name for teacher in teachers">
        </select>


    <button ng-click="vals()">Click</button>

    </div>
</body>

和js

angular.module('MyForm',['Programs'])
.factory('myFactory', function() {
    console.log('Factory loaded');
    var course = {
        program : 'no set',
        setValues : function (data){
            course.program=data.program;
            course.period=data.period;
            course.teacher=data.teacher;
        },
        sayHello : function(){
            alert('hello');
        }
    }
    //console.log(course);
    return course;
})

.controller('mainController',['$scope','myFactory', 'proFactory',function($scope,myFactory,proFactory){

    $scope.vals = function(){
        myFactory.setValues({
            program: $scope.program,
            period: $scope.period,
            teacher: $scope.teacher
        });

        alert('The values are:' +
            '\nProgram: ' + $scope.program +
            '\nProgram: ' + $scope.period +
            '\nProgram: ' + $scope.teacher);
    }

    // to store in programs factory:
    proFactory.set_program($scope.program);

}]) ;

编辑: 如果你真的需要使用工厂在范围之间传递数据,你可以这样定义:

angular.module('Programs',[])
.factory('proFactory',function(){
    var selected_program = '0';

    return {
        set_program: (function(program){ selected_program = program; }),
        get_program: (function(){ return selected_program; })
    };
});

工厂返回一组方法来获取/设置变量(API)

答案 1 :(得分:0)

谢谢benri。

我找到了另一个使用$ parent的解决方案。

在这种情况下,页面有一个mainController(来自myForm模块),其中包含来自不同模块的三个控制器。 每个控制器的$scope适用于每个控制器。我的意思是来自programsController的$ scope不能在periodsControllers中使用。

解决方案是: 使用programsController中ng-model中的$ parent.program,这种方式表示模型绑定到$scope.program的{​​{1}}

HTML是:

mainController

和控制器:

<div ng-controller="programsController">
        <select name="program" id="program" ng-model="$parent.program"
        ng-options="prog.name for prog in programs">
        </select>
</div>