我无法通过本地主机或其他方式让ui.router在index.html上加载组件:
index.html
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.6/angular.min.js"></script> <script src="//unpkg.com/angular-ui-router@0.3.1/release/angular-ui-router.js"></script> <!-- used to route views --> <script src="js/components.js"></script> <body ng-app="myApp"> <div> <!-- main content --> <ui-view></ui-view> <!-- this directs ui-router to put the home view here--> </div>
components.js
var app = angular.module('myApp', ['ui.router']); //makes a call to the Angular API to create our app, configured with the ui.router plug-in //configure our view router app.config(function($stateProvider) { //create our different views as objects var mainState ={ name: 'main', //name of the object url: '', //url to point to, or that causes this view to be triggered component: 'home', //component that works with the data, loads the template resolve: { //data to bind to our component data: function(Resource) { console.log(Resource.test()) //returns "Hello World" return Resource.test() } } } //call the states $stateProvider.state(mainState); }) app.service('Resource', function ($http) { var service = { test: function() { return "Hello world" } } return service; }) app.component('home', { bindings: { data: '<'}, //make the data we loaded into the view from the factory available to this component template: "<p>{{data}}</p>", //this is the html that we will plug our data into controller: function () { console.log(this) //does not call } })
“ Hello world”加载,当我使$ http通过服务时的数据也加载。但是它不会传递给组件。有什么想法吗?
component可从中获取属性ui-router@1.0.0(请参阅此处和CHANGELOG.MD-已在中添加1.0.0-aplpha),因此不可用0.3.1。
component
ui-router@1.0.0
1.0.0-aplpha
0.3.1
这是工作的jsFiddle(带有1.0.3-beta)