首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Movilizer使用MovilizerJS和离子

Movilizer使用MovilizerJS和离子
EN

Stack Overflow用户
提问于 2015-03-25 15:24:32
回答 1查看 390关注 0票数 9

我正在尝试使用MovilizerJS与Ionic框架一起创建一个HTML5屏幕。我尝试从Ionic生成的MovilizerJS文件中引用te App.js。我在plugins文件夹中添加了MovilizerJS文件,并添加了包含Cordova.js文件。

代码语言:javascript
复制
var oHead = document.getElementsByTagName('HEAD').item(0);
var oScript = document.createElement("script");
oScript.type = "text/javascript";
oScript.src = "plugins/Movilizer.js";
oHead.appendChild(oScript);

不过,当我在浏览器中加载HTML5页面(或移动组中的html5视图)时,MovilizerJS似乎不会被加载。浏览器上出现以下错误:

模块‘运动器’是不可用的!

也许我需要将它作为一个模块添加到角度框架中,但是当我试图将它添加到模块中时,它仍然会给我带来错误。我的HTML文件包含移动器的脚本标记:

代码语言:javascript
复制
<script src="plugins/Movilizer.js"></script>

我的App.js代码当前如下所示:

代码语言:javascript
复制
angular.module('starter', ['ionic'])
.run(function($ionicPlatform) { 
      $ionicPlatform.ready(function() {
        // Hide the accessory bar by default (remove this to show the accessory bar above the keyboard
        // for form inputs)
        if(window.cordova && window.cordova.plugins.Keyboard) {
          cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true);
        }
        if(window.StatusBar) {
          StatusBar.styleDefault();
        }

      });
    }).factory('MovilizerExtender', function ($rootScope) {
      return {
        startUpMovilizer: function(){
          movilizer.readGlobalVariable("testTable",this.successCallback,this.errorCallback);
        },
        successCallback: function(result){
          $rootScope.routestops = [
            { ontvNaam: 'nice' },
            { ontvNaam: 'it' },
            { ontvNaam: 'is' },
            { ontvNaam: 'working' }
          ];
       },
       errorCallback: function(){
          console.log('failed');
       }
      }
    }).controller("RoutestopCtrl", function($scope, $rootScope, MovilizerExtender) {
      MovilizerExtender.startUpMovilizer();
      $scope.routestops = $rootScope.routestops;

      $rootScope.$watch('routestops', function(){
          $scope.routestops = $rootScope.routestops;
      });
    });

当我直接调用succesCallback方法并注释行:movilizer.readGlobalVariable(.)时,它不再尝试访问movilizerJS,页面就可以工作了。还请注意,Movilizer.js文件包含app.js代码中描述的readGlobalVariable方法。任何帮助或想法都将不胜感激。

EN

回答 1

Stack Overflow用户

发布于 2016-02-11 17:55:30

尝试引导应用程序而不是使用ng-app

代码语言:javascript
复制
window.onpageshow = ready;
function ready()
{
    var deviceready = new Event("deviceready");
    document.dispatchEvent(deviceready);   
    angular.bootstrap(document, ['starter'], {strictDi: true});  
}

另外,使用承诺等待movilizer

代码语言:javascript
复制
 .factory('MovilizerExtender', function ($q, $rootScope) {
    return {
      startUpMovilizer: function(){
        var self = this;
        var defer = $q.defer();

        rootScope.$watch(function(value) {
          return movilizer && movilizer.readGlobalVariable;
        }, function(ready) {
          if(ready) {
            movilizer.readGlobalVariable("testTable",self.successCallback,self.errorCallback);
          }
          defer.resolve(ready);
        });
        return defer.promise;
      },
      successCallback: function(result){
        $rootScope.routestops = [
          { ontvNaam: 'nice' },
          { ontvNaam: 'it' },
          { ontvNaam: 'is' },
          { ontvNaam: 'working' }
        ];
      },
      errorCallback: function(){
        console.log('failed');
      }
    }
  }).controller("RoutestopCtrl", function($scope, $rootScope, MovilizerExtender) {
    MovilizerExtender.startUpMovilizer().then(function(){
      $scope.routestops = $rootScope.routestops;
    });
    $rootScope.$watch('routestops', function(){
      $scope.routestops = $rootScope.routestops;
    });
  });
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29259795

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档