鸿蒙实现登录后页面跳转

1、在实现实验二中登录界面的基础上,添加一个新页面;

2、点击"登录"按钮后跳转到新页面,并将登录结果作为参数传递到新页面;

3、如果登录成功,在新页面上显示欢迎语;

4、如果登录失败,在新页面上显示"登录失败,无操作权限"。

复制代码
Index.ets
import router from '@ohos.router';
import promptAction from '@ohos.promptAction'

@Entry
@Component
struct LoginPage {
  @State password: string = ''
  @State username: string = ''

  build() {

    Column() {
      Image($r("app.media.panada"))
        .width(100) // 设置图片宽度
        .height(100) // 设置图片高度
        .margin({
          bottom: 60 // 设置图片下方的外边距
        })
      Row() {
        Text("用户名")
          .fontSize(18)
          .fontWeight(FontWeight.Bold)
      }.width("100%")

      Row() {
        Image($r("app.media.login")).width(30)

        TextInput({
          placeholder: "请输入用户名"
        }).width(200).onChange((val: string) => {
          this.username = val

        })
      }.margin({
        bottom: 8,
        top: 8
      }).width("100%")

      Divider().strokeWidth(4)

      Row() {
        Text("密码")
          .fontSize(18)
          .fontWeight(FontWeight.Bold).margin({
          bottom: 8,
          top: 8
        })
      }.width("100%")

      Row() {
        Image($r("app.media.pwd")).width(30)

        TextInput({
          placeholder: "请输入密码"
        }).width(200).onChange((val: string) => {
          this.password = val


        }).type(InputType.Password)
      }.width("100%")

      Divider().strokeWidth(4)
      Row() {
        Blank()
        Text("忘记密码?")
          .fontSize(18)
          .fontWeight(FontWeight.Bold)
      }.width("100%")

      Button("登录").width("90%").height(60).backgroundColor(Color.Blue).onClick(() => {
        if (this.username == "admin" && this.password == "123456") {
          promptAction.showToast({
            message: "输入正确!"
          });
          // 假设您有一个用于页面导航的函数,这里用 router.pushUrl 作为示例
          router.pushUrl({
            url: "pages/Second",
            params: { // 传递参数到新页面
              loginResult: "登录成功!欢迎!"
            }
          });
        } else {
          promptAction.showToast({
            message: "输入错误,请重新输入!"
          });
          // 如果需要,也可以导航到同一个页面或另一个错误页面,并传递登录失败的信息
          router.pushUrl({
            url: "pages/Second", // 或者另一个错误页面
            params: {
              loginResult: "登录失败,无操作权限。"
            }
          });
        }
      });

      Text("第三方登录")
        .fontSize(18).margin({
        bottom: 40,
        top: 60
      })

      Row({ space: 8 }) {
        Image($r("app.media.qq")).width(60)
        Image($r("app.media.wechat")).width(60)

      }

      Text("立即注册")
        .fontSize(18).margin({
        top: 20,
      })

    }
    .width('100%')
    .height('100%')
    .justifyContent(FlexAlign.Center)
    .alignItems(HorizontalAlign.Center)
    .padding({
      left: 20,
      right: 20
    })
  }
}

Second.ets
import router from '@ohos.router';

@Entry
@Component
struct Second {

  @State tips:string = '点击返回到首页'
  @State data:string = router.getParams()?.['loginResult']

  build() {
    Row() {
      Column() {
        if(this.data != null){
          Text(this.data)
            .fontSize(30)
        }
        Button(this.tips)
          .width(200)
          .height(60)
          .fontColor(Color.White)
          .fontSize(20)
          .margin({
            top:20
          })
          .onClick(()=>{
            router.back()
          })
      }
      .width('100%')
    }
    .height('100%')
  }
相关推荐
萌虎不虎6 小时前
【在鸿蒙系统中实现录制视频预览功能】
华为·音视频·harmonyos
m0_685535087 小时前
Zemax 车载前视ADAS镜头
华为·光学·光学设计·光学工程·镜头设计
萌虎不虎9 小时前
【鸿蒙ETS中WebSocket使用说明】
websocket·华为·harmonyos
子榆.14 小时前
Flutter 与开源鸿蒙(OpenHarmony)国际化与无障碍适配指南:打造真正包容的跨平台应用
flutter·华为·开源·harmonyos
C雨后彩虹15 小时前
斗地主之顺子
java·数据结构·算法·华为·面试
子榆.15 小时前
Flutter 与开源鸿蒙(OpenHarmony)深度集成:从原理到实战进阶
flutter·华为·开源·harmonyos
m0_6855350815 小时前
Zemax光学设计宏ZPL学习
华为·光学·光学设计·光学工程·镜头设计
子榆.16 小时前
Flutter 与开源鸿蒙(OpenHarmony)的融合:跨平台开发新纪元
flutter·华为·开源·harmonyos
全球通史16 小时前
HarmonyOS机械臂蓝牙控制应用开发完整教程
华为·harmonyos
爱吃大芒果16 小时前
Flutter 表单开发实战:表单验证、输入格式化与提交处理
开发语言·javascript·flutter·华为·harmonyos