উত্তর:
উভয়ই এসপিএ (একক পৃষ্ঠা অ্যাপ্লিকেশন) এ রাউটিংয়ের উদ্দেশ্যে ব্যবহৃত হিসাবে একই কাজ করে।
কন্ট্রোলার এবং দর্শন (HTML পার্টিয়াল) এর URL গুলি। এটি। অবস্থান.url () দেখে এবং একটি বিদ্যমান রুট সংজ্ঞাতে পাথ মানচিত্রের চেষ্টা করে।
এইচটিএমএল
<div ng-view></div>
উপরের ট্যাগটি কৌণিকের (কনফিগারেশন ফেজ) $routeProvider.when()
আপনি উল্লিখিত শর্তটি থেকে টেমপ্লেট রেন্ডার করবে.config
সীমাবদ্ধতা: -
ng-view
পৃষ্ঠায় একক থাকতে পারে$routeProvider
ব্যর্থ হয়। (যে অর্জন করা, আমরা মত নির্দেশনা ব্যবহার করতে হবে ng-include
, ng-switch
, ng-if
, ng-show
তাদের স্পা আছে, যা খারাপ দেখায়)AngularUI রাউটারটি AngularJS এর জন্য একটি রাউটিং কাঠামো, যা আপনাকে আপনার ইন্টারফেসের অংশগুলি একটি রাষ্ট্রীয় মেশিনে সংগঠিত করতে দেয়। ইউআই-রাউটারগুলি রাজ্যগুলির চারপাশে সংগঠিত করা হয়, এতে বিকল্পভাবে রুটগুলির পাশাপাশি অন্য আচরণও সংযুক্ত থাকতে পারে।
একাধিক ও নামযুক্ত দর্শন
আর একটি দুর্দান্ত বৈশিষ্ট্য হ'ল কোনও টেমপ্লেটে একাধিক ইউআই-ভিউ রাখার ক্ষমতা।
যদিও একাধিক সমান্তরাল দর্শন একটি শক্তিশালী বৈশিষ্ট্য, আপনি প্রায়শই আপনার ইন্টারফেসগুলি আরও কার্যকরভাবে আপনার বাসা বাঁধে view
এবং নীচের রাজ্যের সাথে এই দর্শনগুলিকে যুক্ত করে পরিচালনা করতে সক্ষম হবেন ।
এইচটিএমএল
<div ui-view>
<div ui-view='header'></div>
<div ui-view='content'></div>
<div ui-view='footer'></div>
</div>
বেশিরভাগ ui-router
শক্তি হ'ল এটি নেস্টেড রাষ্ট্র এবং দর্শনগুলি পরিচালনা করতে পারে।
পেশাদাররা
ui-view
একক পৃষ্ঠায় একাধিক থাকতে পারেui-view="some"
কেবলমাত্র @
রাষ্ট্রের নাম সহ পরম রাউটিং ব্যবহার করে রাষ্ট্রের পরিবর্তন করতে পারেন ।@
আপনি পরিবর্তনের জন্য ব্যবহার করে আপেক্ষিক রাউটিংয়ের অন্য উপায়টি হ'ল ui-view="some"
। এটি ui-view
নেস্টেড কিনা তা পরীক্ষা করার পরিবর্তে প্রতিস্থাপন করবে willui-sref
একটি href
ইউআরএল তৈরি করতে ব্যবহার করতে পারেন URL
, এছাড়াও আপনি json
বিন্যাসে একটি স্টেট প্যারাম দিতে পারেন ।আরও তথ্যের জন্য কৌণিক ইউআই-রাউটার
রাজ্যগুলির সাথে বিভিন্ন নেস্টেড ভিউয়ের সাথে আরও ভাল নমনীয়তার জন্য, আমি আপনাকে যেতে পছন্দ করব ui-router
$stateProvider
এবং$routeProvider
কৌনিকের নিজস্ব এনজি-রাউটারটি URLs
রাউটিংয়ের সময় বিবেচনা করে, ইউআই-রাউটারটি states
ইউআরএলগুলি ছাড়াও নেয় ।
রাজ্যগুলি আপনাকে আবেদনের ইন্টারফেসটি শক্তিশালীভাবে পরিচালনা করতে দেয়, নামযুক্ত, নেস্টেড এবং সমান্তরাল দর্শনগুলিতে আবদ্ধ।
এনজি-রাউটারে থাকাকালীন, <a href="">
ট্যাগের মাধ্যমে লিঙ্ক সরবরাহ করার সময় আপনাকে ইউআরএল সম্পর্কে খুব সতর্কতা অবলম্বন করতে হবে , ইউআই -রাউটারে আপনাকে কেবল মাথায় রাখতে হবে state
। আপনি যেমন লিঙ্ক সরবরাহ <a ui-sref="">
। মনে রাখবেন যে <a href="">
আপনি ইউআই-রাউটারে যেমন ব্যবহার করেন, ঠিক তেমনই আপনি এনজি-রাউটারে করেন তবে এটি এখনও কার্যকর হবে।
তাই, এমনকি আপনি যদি কোন একদিন আপনার URL পরিবর্তন করার সিদ্ধান্ত নেন, আপনার state
একই থাকবে এবং আপনি শুধুমাত্র URL টি পরিবর্তন করতে হবে .config
।
যদিও এনজিআরটার সাধারণ অ্যাপ্লিকেশনগুলি তৈরি করতে ব্যবহার করা যেতে পারে, ইউআই-রাউটার জটিল অ্যাপ্লিকেশনগুলির জন্য বিকাশকে আরও সহজ করে তোলে। এখানে এর উইকি
$ রুট: রুটের বিদ্যমান সংজ্ঞা থেকে পথটি মানচিত্রের জন্য এটি নিয়ন্ত্রণকারী এবং দর্শনগুলি (এইচটিএমএল পার্টিয়াল) এবং ঘড়ি $ লোকেশন.আরএল () এর সাথে গভীর সংযোগের URLগুলির জন্য ব্যবহৃত হয়।
যখন আমরা এনজিআরট ব্যবহার করি, রুটটি $ রুটপ্রোভাইডার দিয়ে কনফিগার করা হয় এবং যখন আমরা ইউআই-রাউটার ব্যবহার করি, তখন রুটটি $ statePovider এবং $ urlRouterProvider দিয়ে কনফিগার করা হয়।
<div ng-view></div>
$routeProvider
.when('/contact/', {
templateUrl: 'app/views/core/contact/contact.html',
controller: 'ContactCtrl'
});
<div ui-view>
<div ui-view='abc'></div>
<div ui-view='abc'></div>
</div>
$stateProvider
.state("contact", {
url: "/contact/",
templateUrl: '/app/Aisel/Contact/views/contact.html',
controller: 'ContactCtrl'
});