AngularJS
ui रूटर
खोज…
टिप्पणियों
ui-router
क्या है?
कोणीय यूआई-राउटर एक क्लाइंट-साइड सिंगल पेज एप्लिकेशन राउटिंग फ्रेमवर्क है।
एसपीए के लिए रूटिंग ढांचे ब्राउज़र के यूआरएल को अपडेट करते हैं क्योंकि उपयोगकर्ता ऐप के माध्यम से नेविगेट करता है। इसके विपरीत, यह एप्लिकेशन के माध्यम से नेविगेशन को चलाने के लिए ब्राउज़र के यूआरएल में बदलाव की अनुमति देता है, इस प्रकार उपयोगकर्ता को एसपीए के भीतर गहरे स्थान पर बुकमार्क बनाने की अनुमति देता है।
यूआई-राउटर अनुप्रयोगों को राज्यों के एक श्रेणीबद्ध पेड़ के रूप में तैयार किया जाता है। यूआई-राउटर उन एप्लिकेशन राज्यों के बीच लेनदेन को प्रबंधित करने के लिए एक स्टेट मशीन प्रदान करता है, जैसे लेनदेन।
उपयोगी कड़ियाँ
आप यहां आधिकारिक एपीआई प्रलेखन पा सकते हैं। ui-router
वीएस ng-router
के बारे में प्रश्नों के लिए, आप यहां एक विस्तृत विस्तृत जवाब पा सकते हैं। ध्यान रखें ng-router
ने पहले से ही एनजी-राउटर ( ngNewRouter
1.5 + / 2.0 के साथ संगत) नामक एक नया एनजी-राउटर अपडेट जारी किया है जो यूआई-राउटर जैसे राज्यों का समर्थन करता है। आप यहाँ ngNewRouter
बारे में अधिक पढ़ सकते हैं।
मूल उदाहरण
app.js
angular.module('myApp', ['ui.router'])
.controller('controllerOne', function() {
this.message = 'Hello world from Controller One!';
})
.controller('controllerTwo', function() {
this.message = 'Hello world from Controller Two!';
})
.controller('controllerThree', function() {
this.message = 'Hello world from Controller Three!';
})
.config(function($stateProvider, $urlRouterProvider) {
$stateProvider
.state('one', {
url: "/one",
templateUrl: "view-one.html",
controller: 'controllerOne',
controllerAs: 'ctrlOne'
})
.state('two', {
url: "/two",
templateUrl: "view-two.html",
controller: 'controllerTwo',
controllerAs: 'ctrlTwo'
})
.state('three', {
url: "/three",
templateUrl: "view-three.html",
controller: 'controllerThree',
controllerAs: 'ctrlThree'
});
$urlRouterProvider.otherwise('/one');
});
index.html
<div ng-app="myApp">
<nav>
<!-- links to switch routes -->
<a ui-sref="one">View One</a>
<a ui-sref="two">View Two</a>
<a ui-sref="three">View Three</a>
</nav>
<!-- views will be injected here -->
<div ui-view></div>
<!-- templates can live in normal html files -->
<script type="text/ng-template" id="view-one.html">
<h1>{{ctrlOne.message}}</h1>
</script>
<script type="text/ng-template" id="view-two.html">
<h1>{{ctrlTwo.message}}</h1>
</script>
<script type="text/ng-template" id="view-three.html">
<h1>{{ctrlThree.message}}</h1>
</script>
</div>
एकाधिक दृश्य
app.js
angular.module('myApp', ['ui.router'])
.controller('controllerOne', function() {
this.message = 'Hello world from Controller One!';
})
.controller('controllerTwo', function() {
this.message = 'Hello world from Controller Two!';
})
.controller('controllerThree', function() {
this.message = 'Hello world from Controller Three!';
})
.controller('controllerFour', function() {
this.message = 'Hello world from Controller Four!';
})
.config(function($stateProvider, $urlRouterProvider) {
$stateProvider
.state('one', {
url: "/one",
views: {
"viewA": {
templateUrl: "view-one.html",
controller: 'controllerOne',
controllerAs: 'ctrlOne'
},
"viewB": {
templateUrl: "view-two.html",
controller: 'controllerTwo',
controllerAs: 'ctrlTwo'
}
}
})
.state('two', {
url: "/two",
views: {
"viewA": {
templateUrl: "view-three.html",
controller: 'controllerThree',
controllerAs: 'ctrlThree'
},
"viewB": {
templateUrl: "view-four.html",
controller: 'controllerFour',
controllerAs: 'ctrlFour'
}
}
});
$urlRouterProvider.otherwise('/one');
});
index.html
<div ng-app="myApp">
<nav>
<!-- links to switch routes -->
<a ui-sref="one">Route One</a>
<a ui-sref="two">Route Two</a>
</nav>
<!-- views will be injected here -->
<div ui-view="viewA"></div>
<div ui-view="viewB"></div>
<!-- templates can live in normal html files -->
<script type="text/ng-template" id="view-one.html">
<h1>{{ctrlOne.message}}</h1>
</script>
<script type="text/ng-template" id="view-two.html">
<h1>{{ctrlTwo.message}}</h1>
</script>
<script type="text/ng-template" id="view-three.html">
<h1>{{ctrlThree.message}}</h1>
</script>
<script type="text/ng-template" id="view-four.html">
<h1>{{ctrlFour.message}}</h1>
</script>
</div>
डेटा लोड करने के लिए रिज़ॉल्यूशन फ़ंक्शंस का उपयोग करना
app.js
angular.module('myApp', ['ui.router'])
.service('User', ['$http', function User ($http) {
this.getProfile = function (id) {
return $http.get(...) // method to load data from API
};
}])
.controller('profileCtrl', ['profile', function profileCtrl (profile) {
// inject resolved data under the name of the resolve function
// data will already be returned and processed
this.profile = profile;
}])
.config(['$stateProvider', '$urlRouterProvider', function ($stateProvider, $urlRouterProvider) {
$stateProvider
.state('profile', {
url: "/profile/:userId",
templateUrl: "profile.html",
controller: 'profileCtrl',
controllerAs: 'vm',
resolve: {
profile: ['$stateParams', 'User', function ($stateParams, User) {
// $stateParams will contain any parameter defined in your url
return User.getProfile($stateParams.userId)
// .then is only necessary if you need to process returned data
.then(function (data) {
return doSomeProcessing(data);
});
}]
}
}]);
$urlRouterProvider.otherwise('/');
});
profile.html
<ul>
<li>Name: {{vm.profile.name}}</li>
<li>Age: {{vm.profile.age}}</li>
<li>Sex: {{vm.profile.sex}}</li>
</ul>
यूआई-राउटर विकी एंट्री को यहां देखें ।
$stateChangeSuccess
इवेंट को निकाल दिए जाने से पहले $stateChangeSuccess
फ़ंक्शंस को हल करना होगा, जिसका अर्थ है कि UI लोड नहीं होगा जब तक कि राज्य पर सभी $stateChangeSuccess
फ़ंक्शंस समाप्त नहीं हो जाते। यह सुनिश्चित करने का एक शानदार तरीका है कि डेटा आपके नियंत्रक और UI पर उपलब्ध होगा। हालाँकि, आप देख सकते हैं कि UI को हैंग करने से बचने के लिए एक रिज़ॉल्यूशन फ़ंक्शन तेज़ होना चाहिए।
नेस्टेड व्यू / स्टेट्स
app.js
var app = angular.module('myApp',['ui.router']);
app.config(function($stateProvider,$urlRouterProvider) {
$stateProvider
.state('home', {
url: '/home',
templateUrl: 'home.html',
controller: function($scope){
$scope.text = 'This is the Home'
}
})
.state('home.nested1',{
url: '/nested1',
templateUrl:'nested1.html',
controller: function($scope){
$scope.text1 = 'This is the nested view 1'
}
})
.state('home.nested2',{
url: '/nested2',
templateUrl:'nested2.html',
controller: function($scope){
$scope.fruits = ['apple','mango','oranges'];
}
});
$urlRouterProvider.otherwise('/home');
});
index.html
<div ui-view></div>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.8/angular.min.js"></script>
<script src="angular-ui-router.min.js"></script>
<script src="app.js"></script>
home.html
<div>
<h1> {{text}} </h1>
<br>
<a ui-sref="home.nested1">Show nested1</a>
<br>
<a ui-sref="home.nested2">Show nested2</a>
<br>
<div ui-view></div>
</div>
nested1.html
<div>
<h1> {{text1}} </h1>
</div>
nested2.html
<div>
<ul>
<li ng-repeat="fruit in fruits">{{ fruit }}</li>
</ul>
</div>