gpt4 book ai didi

javascript - 我如何在angularjs中的服务的两个功能之间传递数据

转载 作者:行者123 更新时间:2023-11-30 16:50:16 27 4
gpt4 key购买 nike

我正在尝试创建一个多步骤表单,其中我制作了两个不同的 View 和两个不同的 Controller 我试图将数据从 View 1 传递到服务中定义的函数,然后尝试在另一个函数中访问此数据同样的服务。下面是我写的服务:service.js

var EmployeeService = angular.module('EmployeeService',[])
.service('AddEmployee', function($resource){
var Employee = $resource('/api/meetups');
var emp_email="";
this.email = function(email){
var emp_email = email;
return emp_email;
};

this.personal = function(first_name){
var employee = new Employee();
employee.email = emp_email;
employee.first_name = first_name;
employee.$save();
};
});

我正在尝试将电子邮件函数的 emp_email 变量访问到个人函数中。但我做不到。有什么方法可以在我的第二个函数中使用 emp_email 变量。

以下是使用服务的 Controller :

app.controller('mainCrl', ['$scope', '$resource', '$location', 'AddEmployee', function ($scope, $resource, $location, AddEmployee){
$scope.nextSection = function(){
$scope.email = AddEmployee.email($scope.employeeEmail);
};
}]);
app.controller('secondCrl', ['$scope', '$resource', '$location', 'AddEmployee', function ($scope, $resource, $location, AddEmployee){
$scope.secondSection = function(){
$scope.first_name = AddEmployee.personal($scope.first_name);
};
}]);

nextSection 函数将在用户填写电子邮件并点击下一节时执行,secondSection 函数将在用户在第二个 View 中输入 first_name 并点击提交时执行。

如何在服务中的两个函数之间传递数据?非常感谢任何形式的帮助!!!!

最佳答案

您的代码的问题是您在电子邮件函数中创建了第二个“emp_email”变量,因此您分配的电子邮件将转到电子邮件函数中的本地 emp_email 变量,而不是 emp_email服务函数中的变量。

所以删除var并更改

this.email = function(email){
var emp_email = email;
return emp_email;
};

this.email = function(email){
emp_email = email;
return emp_email;
};

这应该允许您在函数之间共享 emp_email 变量。

关于javascript - 我如何在angularjs中的服务的两个功能之间传递数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30630310/

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