角度UI路由器无法在chrome应用程序上运行

Angular UI router not working on chrome app

本文关键字:应用 应用程序 程序上 运行 chrome UI 路由器 角度      更新时间:2023-09-26

我正在使用带有angular-ui-router angularjs创建一个 chrome 应用程序。

应用.js

var foo = angular.module('foo', [
    'ui.router',
])
.config(['$stateProvider', '$locationProvider',
    function($stateProvider, $locationProvider) {
    console.log("This works fine.");
    $stateProvider
        .state('login', {
            url: '/',
            templateUrl: 'modules/login/templates/login.html',
            controller: 'loginController'
        })
}])

登录.js

foo.controller('loginController',
    ['$scope',
    function($scope){
    console.log("This should be printed on the console.");
}])

窗口.html

<!DOCTYPE html>
<html ng-app="mycurechrome">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <script src="components/chromestrap/js/jquery-2.0.3.min.js"></script>
    <script src="components/chromestrap/js/bootstrap.min.js"></script>
    <script src="bower_components/angular/angular.min.js"></script>
    <script src="bower_components/angular-ui-router/release/angular-ui-router.min.js"></script>
    <script src="app.js"></script>
    <script src="modules/login/controllers/login.js"></script>
    <link href="components/chromestrap/css/bootstrap.min.css" rel="stylesheet">
    <link href="css/window.css" rel="stylesheet">
</head>
<body>
    <div ui-view></div>
</body>
</html>

manifest.json

{
    "name": "foo",
    "description": "bar",
    "version": "0.1",
    "manifest_version": 2,
    "app": {
        "background": {
            "scripts": [
                "background.js"
            ]
        }
    },
    "icons": { "16": "icon-16.png", "128": "icon-128.png" }
}

背景.js

chrome.app.runtime.onLaunched.addListener(function() {
    chrome.app.window.create('window.html', {
        'outerBounds': {
            'width': 1000,
            'height': 600
        }
    });
});

app.js执行console.log("This works fine.");,但login.js上的 log() 不会。

我不认为我使用ui-router错,但我持怀疑态度,因为谷歌浏览器应用程序可能有不同的方法。

尝试导航到登录状态,如果这是您的默认状态,请尝试:

.config(['$stateProvider', '$locationProvider', '$urlRouterProvider',
    function($stateProvider, $locationProvider, $urlRouterProvider) {
    console.log("This works fine.");
    $urlRouterProvider.otherwise('/login');
    $stateProvider
        .state('login', {
            url: '/login',
            templateUrl: 'modules/login/templates/login.html',
            controller: 'loginController'
        });
}]);