SAP Spartacus的navigation初始化
2020-12-30 本文已影响0人
华山令狐冲
SAP Spartacus navigation入口:
data:image/s3,"s3://crabby-images/6f324/6f324f1325fdfc7ea7dd575b7d536ec6895b12f6" alt=""
/**
* Sets up the location change listener and performs the initial navigation.
*/
initialNavigation() {
this.setUpLocationChangeListener();
if (this.navigationId === 0) {
this.navigateByUrl(this.location.path(true), { replaceUrl: true });
}
}
/**
* Navigates to a view using an absolute route path.
*
* @param url An absolute path for a defined route. The function does not apply any delta to the
* current URL.
* @param extras An object containing properties that modify the navigation strategy.
* The function ignores any properties in the `NavigationExtras` that would change the
* provided URL.
*
* @returns A Promise that resolves to 'true' when navigation succeeds,
* to 'false' when navigation fails, or is rejected on error.
*
* @usageNotes
*
* The following calls request navigation to an absolute path.
*
* ```
* router.navigateByUrl("/team/33/user/11");
*
* // Navigate without updating the URL
* router.navigateByUrl("/team/33/user/11", { skipLocationChange: true });
* ```
*
* @see [Routing and Navigation guide](guide/router)
*
*/
navigateByUrl(url, extras = { skipLocationChange: false }) {
if (isDevMode() && this.isNgZoneEnabled && !NgZone.isInAngularZone()) {
this.console.warn(`Navigation triggered outside Angular zone, did you forget to call 'ngZone.run()'?`);
}
const urlTree = isUrlTree(url) ? url : this.parseUrl(url);
const mergedTree = this.urlHandlingStrategy.merge(urlTree, this.rawUrlTree);
return this.scheduleNavigation(mergedTree, 'imperative', null, extras);
}
data:image/s3,"s3://crabby-images/7ff5b/7ff5b221ca3edbf8324530cf057f7e108b526e1d" alt=""
data:image/s3,"s3://crabby-images/9bbd1/9bbd144d65054ac3f5312cc731555a411a76f9a2" alt=""
data:image/s3,"s3://crabby-images/dcb98/dcb9820bee153eaf9fd0e243559e04c04fc0a77b" alt=""
RouterStateSnapshot的url字段里包含的electronics-spa/en/USD是怎么来的?
data:image/s3,"s3://crabby-images/599b6/599b6ea2ef06e08d659c1bc69416afe2859b4920" alt=""
ActivatedRouteSnapshot
data:image/s3,"s3://crabby-images/952ce/952ce9e6d6b7fbd8809e1fc1254f8f270bf89f6a" alt=""
array是一个闭包:
data:image/s3,"s3://crabby-images/80791/807919007b53d6993636bd3fd7e4dc6270945d97" alt=""
此时还没有从后台请求数据,前台怎么知道url应该为electronics-spa/en/USD?
data:image/s3,"s3://crabby-images/b2f92/b2f922aac20140ea0a9839c141d6212e9b575772" alt=""