Pase un valor de campo de entrada en AngularJS $ Resource indefinido y el error muestra un proveedor de alcance desconocido

StackOverflow https://stackoverflow.com//questions/25083305

Pregunta

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

actualización 1 Código fijo Produce un nuevo error de

ReferenceError: inputName is not defined

en la línea de

 inputName:inputName,

a continuación es el nuevo código

<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>

Me pregunto dónde lo entiendo mal?

gracias

¿Fue útil?

Solución

http://plnkr.co/edit/ckgwr.ibmugrkdx5p?p=preview

Algunos problemas que arreglé que otros señalaron en el comentario.

Eliminar $ alcance de fábrica.Aquí está obteniendo un objeto genérico de $ alcance, pero no el alcance real.Lo conseguirás en el controlador. Cuando llame a un recurso angular con consulta () el primer argumento ya es el param.Pero puede especificar los parámetros comunes como lo hizo antes.

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

Espero que esto ayude.

Otros consejos

inputName:inputName,

El segundo nombre de entrada se refiere a la variable no existente.Creo que esta línea se puede eliminar en absoluto.Pero depende de lo que quieras lograr.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top