目录
案例:使用router完成页面跳转
1.创建一个Arkts项目
打开DevEco Studio开发工具 ====》 点击Create Project ===》创建项目
data:image/s3,"s3://crabby-images/dc50e/dc50ee1d2dfed69b5e4223b71b1c4336b15ba1f8" alt=""
选中Empty Ability ===> 点击next ===>
data:image/s3,"s3://crabby-images/68d83/68d833584c03abf009b81054a39e808834ce5162" alt=""
在新弹出的界面填写相关信息===》点击finsh ===>等待界面打开
data:image/s3,"s3://crabby-images/d9051/d90514bc5e65a87ba350f6907c8000e5d822ad34" alt=""
data:image/s3,"s3://crabby-images/8a518/8a5188dd6ea113b660a8398521a4ac471aafbbf6" alt=""
2.创建第二个页面
找到page ==>鼠标右键 ==》new ==> page ====>Empty View==>在新弹出的界面====》点击finsh ===>等待创建就可以了
data:image/s3,"s3://crabby-images/5ab80/5ab801d5f445de9f399d6f640dc0c831869062bf" alt=""
data:image/s3,"s3://crabby-images/9f435/9f4359dc96b2f6abbebaf3b490c988487cba9e4d" alt=""
data:image/s3,"s3://crabby-images/f4c3c/f4c3c156b2b29bd464e7b310448a1f809d1e8779" alt=""
3.手动创建第三个页面
data:image/s3,"s3://crabby-images/f32ed/f32ed7896f928cb649cccfdcf20b171c7016f1bc" alt=""
data:image/s3,"s3://crabby-images/a8d0e/a8d0e2bef93c0169e2e9ea909300abb36cec5485" alt=""
在新弹出的界面编写代码
TypeScript@Entry //页面入口标记 @Component struct MyDivPage { build() { Column(){ Text("这是我手动创建的页面") .id('text') .fontSize(50) .fontWeight(FontWeight.Bold) .alignRules({ center: { anchor: '__container__', align: VerticalAlign.Center }, middle: { anchor: '__container__', align: HorizontalAlign.Center } }) } .width('100%') .height('100%') } }
预览效果
data:image/s3,"s3://crabby-images/80fa4/80fa4e9267d0294ee0005e6281a9869ed6dd070f" alt=""
在resources ===》base ==> profile ===> 双击 main_pages.json ==>配置手动创建的页面
data:image/s3,"s3://crabby-images/80c67/80c67b6bd0a2dba934f508f8bdabfe992a290058" alt=""
4.编写跳转路由
1--导入路由
import router from '@ohos.router';
2--编写代码
TypeScriptimport router from '@ohos.router'; @Entry @Component struct Index { @State message: string = '这个是首页'; build() { Column() { Text(this.message) .id('HelloWorld') .fontSize(50) .fontWeight(FontWeight.Bold) .alignRules({ center: { anchor: '__container__', align: VerticalAlign.Center }, middle: { anchor: '__container__', align: HorizontalAlign.Center } }) Text() .backgroundImage($r('app.media.girl_two')) .width(300) .height(300) //按钮跳转携带参数跳转页面 Button("跳转携带参数") .onClick(() => { router.push({ url: 'pages/Page', params: { name: '惜.己', age: 18 } }) }) } .height('100%') .width('100%') } }
data:image/s3,"s3://crabby-images/9519a/9519aba0e03152a619dcb1916b9d7c6125583c4d" alt=""
5.编写接受路由
结构对象中的参数 param['属性名']
@State params: object = router.getParams();
name: string = params[my_name]
TypeScriptimport router from '@ohos.router'; @Entry @Component struct Page { @State message: string = '这是这是第二个页面'; //手动接受跳转过来的数据 @State params: object = router.getParams(); build() { Column() { Text(this.message) .id('PageHelloWorld') .fontSize(50) .fontWeight(FontWeight.Bold) .alignRules({ center: { anchor: '__container__', align: VerticalAlign.Center }, middle: { anchor: '__container__', align: HorizontalAlign.Center } }) Text("名字是:"+this.params['my_name']+"\n年龄:"+this.params['my_age']) .id('name') Button("不带参数跳转") .onClick(()=>{ router.pushUrl({ url: 'pages/MyDivPage' }) }) Button("返回上一个界面") .onClick(()=>{ router.back() }) } .height('100%') .width('100%') } }
6.编写返回上一个页面的代码
Button("返回上一个界面") .onClick(()=>{ router.back() })
第二个界面完善的代码
TypeScriptimport router from '@ohos.router'; @Entry @Component struct Page { @State message: string = '这是这是第二个页面'; //手动接受跳转过来的数据 @State params: object = router.getParams(); build() { Column() { Text(this.message) .id('PageHelloWorld') .fontSize(50) .fontWeight(FontWeight.Bold) .alignRules({ center: { anchor: '__container__', align: VerticalAlign.Center }, middle: { anchor: '__container__', align: HorizontalAlign.Center } }) Text("名字是:"+this.params['my_name']+"\n年龄:"+this.params['my_age']) .id('name') Button("不带参数跳转") .onClick(()=>{ router.pushUrl({ url: 'pages/MyDivPage' }) }) Button("返回上一个界面") .onClick(()=>{ router.back() }) } .height('100%') .width('100%') } }
data:image/s3,"s3://crabby-images/23472/23472336f5bb6529c47ca57fa8a1e953392b1cb8" alt=""
7.第三个界面代码完善
TypeScriptimport { router } from '@kit.ArkUI' @Entry //页面入口标记 @Component struct MyDivPage { build() { Column(){ Text("这是我手动创建的页面") .id('text') .fontSize(50) .fontWeight(FontWeight.Bold) .alignRules({ center: { anchor: '__container__', align: VerticalAlign.Center }, middle: { anchor: '__container__', align: HorizontalAlign.Center } }) Button("返回上一个界面") .onClick(()=>{ router.back() }) } .width('100%') .height('100%') } }
data:image/s3,"s3://crabby-images/be728/be72895b53bc3a3ea33521a02bc9e76aa694a143" alt=""
8.效果
data:image/s3,"s3://crabby-images/9bbfe/9bbfe8c549025299b09822af232d6ed406d3e4a1" alt=""
案例:使用want启动Ability
1.创建一个新的项目
data:image/s3,"s3://crabby-images/3c3c2/3c3c25cb7adab5b600779be18fcdc4294403ce67" alt=""
data:image/s3,"s3://crabby-images/62e3e/62e3e892d0942a5f177d4669820d1a9895af1404" alt=""
data:image/s3,"s3://crabby-images/677db/677dbc41acf4398f5d7778c3cbd131f641e01e2c" alt=""
data:image/s3,"s3://crabby-images/034a7/034a7afaab17e0de4b560abe665ad6ba497f8f61" alt=""
2.创建第二个界面
page ===> 鼠标右键===>new Page ===> Empty Page ===>在新的界面填写信息===》finsh
data:image/s3,"s3://crabby-images/86dce/86dce29b16e7a47660f6ea6c4ae2b08fd516ee93" alt=""
data:image/s3,"s3://crabby-images/4987c/4987cb6cfbf9e2c3847f7ead4677ceb00dcfb1ab" alt=""
页面内容
TypeScript@Entry @Component struct MySecond { @State message: string = 'Hello World'; build() { RelativeContainer() { Text(this.message) .id('MySecondHelloWorld') .fontSize(50) .fontWeight(FontWeight.Bold) .alignRules({ center: { anchor: '__container__', align: VerticalAlign.Center }, middle: { anchor: '__container__', align: HorizontalAlign.Center } }) } .height('100%') .width('100%') } }
3.创建一个Ability
ets ==> 鼠标右键 ===> new ===> Ability ==>鼠标点击
data:image/s3,"s3://crabby-images/7701b/7701b9f901034d3f7b7e81a2dfc925fe79cd9797" alt=""
填写信息 ===> finsh
data:image/s3,"s3://crabby-images/84012/84012383078c7a5490453717e2c035efc738852e" alt=""
data:image/s3,"s3://crabby-images/3bc36/3bc36e52e83e5989c8218e983559bddd81b7c836" alt=""
4.修改新生成的Ability中的信息
按照图修改即可
data:image/s3,"s3://crabby-images/86495/86495eeee90cfa4315b41e9258acea643839b5a7" alt=""
修改之后
data:image/s3,"s3://crabby-images/c4ae7/c4ae79f13b965b007cdeedeecdb5fe62556b6763" alt=""
5.编写Index.ets中的代码
//导入要使用的组件
import { common, Want } from '@kit.AbilityKit';
//获取上下文
private context = getContext(this) as common.UIAbilityContext;
TypeScriptimport { common, Want } from '@kit.AbilityKit'; @Entry @Component struct Index { @State message: string = '第一个页面'; private context = getContext(this) as common.UIAbilityContext; build() { Column() { Text(this.message) .id('HelloWorld') .fontSize(50) .fontWeight(FontWeight.Bold) .alignRules({ center: { anchor: '__container__', align: VerticalAlign.Center }, middle: { anchor: '__container__', align: HorizontalAlign.Center } }) Button("显式跳转") .onClick(() => { const want: Want = { bundleName: 'com.xiji.myapplication', abilityName: 'MySecond' } this.context.startAbility(want,()=>{ console.log("跳转成功") }) }) // 启动按钮 } .height('100%') .width('100%') //函数 } }
下面这张图搞懂BundleName和AbilityName
data:image/s3,"s3://crabby-images/1b5ed/1b5ede7beced33c591d21ac170311d74d5feb10f" alt=""
6.效果图
data:image/s3,"s3://crabby-images/b7c01/b7c014bf55de1ff09ec6a7fec1bbb629159286b6" alt=""
7.编写隐式启动代码
1)编写module.json5文件
找到module.json5中我们要启动的ability中的这一项,并且一下内容
"skills": [{ "actions": [ "mySecond" ] }],
data:image/s3,"s3://crabby-images/1f58a/1f58a383606b6bba54d236a130706f412c6e584a" alt=""
2)编写index.ets中的内容
TypeScriptimport { common, Want, wantConstant } from '@kit.AbilityKit'; @Entry @Component struct Index { @State message: string = '第一个页面'; private context = getContext(this) as common.UIAbilityContext; build() { Column() { Text(this.message) .id('HelloWorld') .fontSize(50) .fontWeight(FontWeight.Bold) .alignRules({ center: { anchor: '__container__', align: VerticalAlign.Center }, middle: { anchor: '__container__', align: HorizontalAlign.Center } }) Button("显式跳转") .onClick(() => { const want: Want = { bundleName: 'com.xiji.myapplication', abilityName: 'MySecond' } this.context.startAbility(want,()=>{ console.log("跳转成功") }) }) // 启动按钮 Button("隐式跳转") .onClick(() => { const want: Want = { action: "mySecond" } this.context.startAbility(want,()=>{ console.log("跳转成功") }) }) } .height('100%') .width('100%') //函数 } }
8.隐式启动效果图
data:image/s3,"s3://crabby-images/b0999/b0999f8afbde07a6bd3de3caf6afa25affd96e6e" alt=""