javascript - Angular 提供程序必须从 $get 工厂方法返回一个值

标签 javascript jquery angularjs proj4js

所以我的 Angular 工厂有一个问题,我已经尝试解决了一段时间了。我想我对 Angular 了解还不够。

我将在此处发布的大部分代码都是重复使用了我没有编写的解决方案另一部分的代码。所以这可能就是我无法弄清楚的原因。 这也是我 build 的第一家工厂。

(function () {
'use strict';

angular.module('app.coordinate-transformer-service', [])
    .factory('coordinateTransformerService', coordinateTransformerService);

coordinateTransformerService.$inject = ['proj4js', 'gmaps'];

function coordinateTransformerService(proj4js, gmaps, objectsEpsgCode) {

    var factory = {};

    factory.$get = ['proj4js', function coordinateTransformerFactory(proj4js) {
        return new coordinateTransformerService(proj4js, gmaps, objectsEpsgCode);
    }];

    var mapProjection = 'EPSG:4326', // WGS84 latlong
            objectsProjection = 'EPSG:' + objectsEpsgCode,
            transformCoordinatesToLatLng = function (point) {
                if (objectsProjection === mapProjection) {
                    return new gmaps.LatLng(point.y, point.x);
                }

                var newPoint = {
                    x: point.x,
                    y: point.y
                };
                proj4js.transform(new proj4js.Proj(objectsProjection), new proj4js.Proj(mapProjection), newPoint);
                return new gmaps.LatLng(newPoint.y, newPoint.x);
            };

    factory.transformLatLngToProject = function (latlng) {
        if (!factory.isFunction(latlng.lng) || !factory.isFunction(latlng.lat)) {
            throw new Error("No functions lat() or lng() exists on parameter latlng");
        }

        var newPoint = {
            x: latlng.lng(),
            y: latlng.lat()
        };

        proj4js.transform(new proj4js.Proj(mapProjection), new proj4js.Proj(objectsProjection), newPoint);
        newPoint = roundPointsToCorrectDecimals(newPoint);

        return newPoint;
    };

    factory.roundPointsToCorrectDecimals = function (point) {
        var noDecimals = objectsEpsgCode === 4326 ? 5 : 0;

        if (!point || !point.x || !point.y) {
            throw new Error("Point, x or y is null or not defined");
        }

        return {
            x: point.x.toFixed(noDecimals),
            y: point.y.toFixed(noDecimals)
        };
    };

    factory.isFunction = function (functionToCheck) {
        var getType = {};
        return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
    };

    return factory;
};

//coordinateTransformerService.prototype = {
//    constructor: coordinateTransformerService
//};
//return coordinateTransformerService;
})();

我收到错误“Provider 'proj4js' 必须从 $get 工厂方法返回一个值。” 老实说,我不知道我的factory.$get 函数是做什么的。这是我没有编写的代码的一部分。 Proj4js 是一个将坐标从一个系统转换为另一个系统的库。 因此,我们从服务器加载对象以将它们显示在谷歌地图上,其中一些不使用纬度经度。所以这就是为什么我们需要用 proj4js 来改造它们。如果该信息对任何人都有帮助。

但我知道工厂方法需要返回一个对象。但我不是已经这样做了吗? 也许是factory.$get函数才是问题所在,正如我所说,我不知道它的目的......但是删除它并没有帮助^^

另外,不要介意它被称为coodinateTransformerService 而不是coordinatorTransformerFactory。我首先使用了一个服务,只是在它开始工作之前不想重命名它。

编辑:这可能会有所帮助。在 angular.js 中抛出错误:

function enforceReturnValue(name, factory) {
return function enforcedReturnValue() {
  var result = instanceInjector.invoke(factory, this, undefined, name);
  if (isUndefined(result)) {
    throw $injectorMinErr('undef', "Provider '{0}' must return a value from $get factory method.", name);
  }
  return result;
};
}

结果未定义。名字是proj4js,工厂是这个同事做的:

(function () {
'use strict';

angular.module('blocks.proj4js').factory('proj4js', proj4jsFactory);

proj4jsFactory.$inject = ['$window'];
function proj4jsFactory($window) {
    return $window.proj4js;
}
})();

最佳答案

据我所知,您混淆了服务和提供商。满足您的需求的最简单方法是:

angular.module('app.coordinate-transformer-service', [])
    .service('coordinateTransformerService', CoordinateTransformerService);

CoordinateTransformerService.$inject = ['proj4js', 'gmaps', 'objectsEpsgCode'];

function CoordinateTransformerService(proj4js, gmaps, objectsEpsgCode) {

    var mapProjection = 'EPSG:4326', // WGS84 latlong
            objectsProjection = 'EPSG:' + objectsEpsgCode,
            transformCoordinatesToLatLng = function (point) {
                if (objectsProjection === mapProjection) {
                    return new gmaps.LatLng(point.y, point.x);
                }

                var newPoint = {
                    x: point.x,
                    y: point.y
                };
                proj4js.transform(new proj4js.Proj(objectsProjection), new proj4js.Proj(mapProjection), newPoint);
                return new gmaps.LatLng(newPoint.y, newPoint.x);
            };

    this.transformLatLngToProject = function (latlng) {
        if (!this.isFunction(latlng.lng) || !this.isFunction(latlng.lat)) {
            throw new Error("No functions lat() or lng() exists on parameter latlng");
        }

        var newPoint = {
            x: latlng.lng(),
            y: latlng.lat()
        };

        proj4js.transform(new proj4js.Proj(mapProjection), new proj4js.Proj(objectsProjection), newPoint);
        newPoint = roundPointsToCorrectDecimals(newPoint);

        return newPoint;
    };

    this.roundPointsToCorrectDecimals = function (point) {
        var noDecimals = objectsEpsgCode === 4326 ? 5 : 0;

        if (!point || !point.x || !point.y) {
            throw new Error("Point, x or y is null or not defined");
        }

        return {
            x: point.x.toFixed(noDecimals),
            y: point.y.toFixed(noDecimals)
        };
    };

    this.isFunction = function (functionToCheck) {
        var getType = {};
        return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
    };
};

关于javascript - Angular 提供程序必须从 $get 工厂方法返回一个值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30452295/

相关文章:

javascript - JQuery点击事件,不工作

javascript - AngularJS $超时不起作用

javascript - 如何设置全局变量以提高主导航菜单的可见性

java - 通过 JS 调用 JSF 方法

javascript - 在 ruby​​ on Rails 中使用 jquery getJSON 获取数据

javascript - Localstorage 作为 Javascript 函数属性值

javascript - 注销后如何在不使用浏览器缓存的情况下从服务器重新加载 Angular 应用程序

javascript - 未捕获的类型错误 : getElementsByName is not a function

javascript - 重叠的 HTML 元素

javascript - 更改数据表内的列名称