Click the blue text ╳ to follow us
Introduction
Effect Diagram
data:image/s3,"s3://crabby-images/320d7/320d779cc2182cb089dda47b6ea17749985cc057" alt="Arouter: A Lightweight and Efficient Page Routing Tool"
Usage Instructions
Arouter supports the following features:
● Supports routing navigation between pages;
● Supports parameterized navigation and callbacks;
● Supports configuring navigation interceptors;
● Supports pre-processing navigation;
Routing Navigation
import {Arouter} from "@ohos/arouteronactivityresult";Arouter.getInstance() .build("--/--") // The address to navigate to .navigation()
import {Arouter} from "@ohos/arouteronactivityresult";Arouter.getInstance() .build("--/--") // The address to navigate to .withParams({index:"--"}) .navigation()
import {NavigationCallback} from '@ohos/arouteronactivityresult'var callback:NavigationCallback = { onInterrupt(postcard){}, onArrival(postcard){}, onActivityResult(data){}}
import {Arouter} from "@ohos/arouteronactivityresult";Arouter.getInstance() .build("--")// The address to navigate to .navigationWithCallback(callback)
import router from '@ohos.router';if (postcard == null) { postcard = Arouter.getInstance().getPostcard(router.getState().path+router.getState().name); }
postcard.getNavigationCallback().onActivityResult(params)
Routing Interception
import {Postcard,IInterceptor,InterceptorCallback} from '@ohos/arouteronactivityresult';var iInterceptor:IInterceptor= { process(postcard:Postcard, interceptorCallback:InterceptorCallback) { // Select the page to intercept, if the path is present during the navigation, prompt for interception; if not, navigate directly. if (Postcard.getUri() == 'pages/transit') { // Select the dialog box AlertDialog.show( { message: 'Intercepted, click to continue navigation', primaryButton: { value: 'Cancel', action: () => { // Interrupt navigation interceptorCallback.onInterrupt(postcard) } }, secondaryButton: { value: 'Continue', action: () => { // Continue navigation interceptorCallback.onContinue(postcard); } }, } ) } else { // Continue navigation interceptorCallback.onContinue(postcard); } }}
import {registerInterceptor} from '@ohos/arouteronactivityresult';registerInterceptor(iInterceptor);
import {unregisterInterceptor} from '@ohos/arouteronactivityresult';unregisterInterceptor()
Arouter.getInstance() .build("--/--")// The address to navigate to .setGreenChannel(true) .navigation()
import {PretreatmentService} from '@ohos/arouteronactivityresult';var pretreatmentService:PretreatmentService = { onPretreatment(postcard:Postcard):boolean{ return true }}
Call the .setPretreatmentService() method before navigation to pass the pretreatmentService into the setPretreatmentService() method to complete the pre-processing functionality.
Arouter.getInstance() .build(this.router) .setPretreatmentService(pretreatmentService) .navigationWithCallback(callback)
Interface Description
data:image/s3,"s3://crabby-images/b5251/b5251bf94c98a98e824a1e45e1d950cd892f142b" alt="Arouter: A Lightweight and Efficient Page Routing Tool"
data:image/s3,"s3://crabby-images/d3ff9/d3ff9a354e97701faa88ffdb7c1e70b2500fb325" alt="Arouter: A Lightweight and Efficient Page Routing Tool"
Installation and Download
ohpm install @ohos/arouteronactivityresult
Source Code Link