0

我们有一个使用 Ionic 和 Rails 作为 API 开发的移动应用程序。现在我们计划在 Web 应用程序中重用 PhoneGap 代码和 Ionic 标签。我仍然不完全确定这是否可能。有人试过这个吗?我看到将 Ionic 代码(位于 www/ 中)放在 Lamp 服务器中可以在浏览器中打开(我在本地尝试过)。那是正确的方法吗?有人可以为此建议我一个更好的方法。也非常感谢相同的指南或链接。

4

1 回答 1

2

是的,我已经开发了一些基于 Ionic 框架的混合应用程序以及相应的 Web 应用程序,可重用高达 90% 的代码库。

webapp 项目与混合应用项目共享几乎所有的 Angular 模块,特别是服务和指令。一些功能和特定于移动设备的特性被包装在一个模块中,这对于混合项目和 webapp 项目是不同的。

例如,我有一个用于混合(离子)项目的wrapper.ionic.js,其中包含例如这个工厂:

angular.module('components.wrapper', [])
.factory('$myPopup', ['$ionicPopup', function($ionicPopup) {
    var scope = {};

    scope.alert = function (params) {
        return $ionicPopup.alert(params);
    }

    scope.show = function (params) {
        return $ionicPopup.show(params);
    }

    scope.confirm = function (params) {
        return $ionicPopup.confirm(params);
    }

    return scope;
}])
...

webapp 项目的对应物是wrapper.bootstrap.js(基于https://angular-ui.github.io):

angular.module('components.wrapper', [])
.factory('$myPopup', ['$modal', function($modal) {
    var scope = {};

    scope.animation = true;
    scope.size = 'sm';          // values: '', 'lg', 'sm'

    scope.alert = function (params) {
        var alert = $modal.open({
            animation: scope.animation,
            size: scope.size,
            backdrop: true,
            template:
              '<div class="modal-header"><h4 class="modal-title '+params.cssClass+'">'+params.title+'</h4></div>' +
              '<div class="modal-body '+params.cssClass+'">' +params.template + '</div>' +
              '<div class="modal-footer"><button class="button button-positive" type="button" ng-click="cancel()">Ok</button>' +
              '</div>',
            controller: ['$scope', '$modalInstance', function ($scope, $modalInstance) {
                $scope.cancel = function () {
                    $modalInstance.dismiss('cancel');
                };
            }],
            controllerAs: 'ctrl'
        });
        return alert;
    }
...

因此,您可以在混合和 webapp 中使用该服务$myPopup

关于 HTML(索引和视图模板),情况更加复杂。许多 Ionic 标签(指令和 CSS)对移动设备友好,但没有针对可以从桌面看到的 web 应用程序进行优化。在这里,我使用了 Ionic 标签和 UI Boostrap,但更喜欢第二个。

于 2015-12-15T08:04:00.270 回答