0

==================================================== ==========================

更新 1 固定代码产生新的错误

ReferenceError: inputName is not defined

线上

 inputName:inputName,

下面是新代码

<script src="/library/angularjs/1.2.0-rc.3/angularjs.js"></script>
<script src="/library/angularjs/1.2.0-rc.3/angular-route.js"></script>
<script src="/library/angularjs/1.2.0-rc.3/angular-resource.js"></script>
<script>
var app= angular.module('myApp', ['ngRoute', 'ngResource']);
app.factory('Greeter', ['$resource',function($resource){
  return $resource(
    'http://123.com/processor.php',
    {
      inputName:inputName,
      callback: 'JSON_CALLBACK'

    },
    {
      query: {method:'GET',isArray:true}
    });
}]);

app
.controller('MyCtrl', ['$scope', 'Greeter',
  function($scope,Greeter){
  /*alert("yes");*/
  $scope.greet = function(){
    //alert("greetttt");
    alert("before greeeter"+$scope.inputName);
    Greeter.query(
      {inputName:$scope.inputName},
      function(response){
        alert(response[0].myCodeId);
        $scope.output=response[0].myCodeId;
      }
    );
  };
}]);
</script>
<div ng-app="myApp">
  <div ng-controller="MyCtrl">
  Your name:
    <input type="text" ng-model="inputName" name="myInput" value="World"/>
    <button ng-click="greet()">greet</button>

  <div>
  Test Output Here

    {{output}}

  </div>
  </div>
</div>

我想知道我哪里弄错了?

谢谢

4

2 回答 2

1

http://plnkr.co/edit/CKgWrson3IbMugRKdX5p?p=preview

我修复了其他人在评论中指出的一些问题。

从工厂中删除 $scope。在这里,您得到的是一个通用的 $scope 对象,但不是实际的范围。你会在控制器中得到它。当您使用 query() 调用角度资源时,第一个参数已经是参数。但是您可以像以前一样指定常用参数。

function($resource) {
  return $resource('mocked-resource.json', {
    callback: 'JSON_CALLBACK'
  }, {
    query: {
      method: 'GET',
      isArray: true
    }
  });

希望这可以帮助。

于 2014-08-01T17:01:50.793 回答
0
inputName:inputName,

第二个 inputName 引用不存在的变量。我认为这条线可以完全删除。但这取决于您想要实现的目标。

于 2014-08-01T16:59:09.123 回答