【前端】登录页面扩展点

登录页面扩展点

场景

1: 登录之前需要二次确认框
2: 前端默认的错误提示允许被修改
3: 后端返回的错误提示允许被修改
4: 登录后跳转到自定义的页面

方案

前端默认错误可枚举

errorMessages: {
    loginEmpty: '用户名不能为空',
    passwordEmpty: '密码不能为空',
    picCodeEmpty: '图形验证码不能为空',
    phoneEmpty: '手机号不能为空',
    verificationCodeEmpty: '验证码不能为空',
    picCodeError: '图形验证码错误',
    inputVerificationCodeAlign: '请重新输入验证码'
 }

登录按钮添加拓展点beforeClickafterClick

代码

新增一个ts文件,继承平台默认的LoginPageWidget

@SPI.ClassFactory(RouterWidget.Token({ widget: 'Login' }))
export class CustomLoginPageWidget extends LoginPageWidget {
  constructor() {
    super();

    // 修改前端默认的错误文案
    this.errorMessages.loginEmpty = '登录用户名不能为空';
  }

  /**
   * 用来处理点击「登录」之前的事件,可以做二次确定或者其他的逻辑
   * 只有return true,才会继续往下执行
   */
  public beforeClick(): Promise<Boolean | null | undefined> {
    return new Promise((resolve) => {
      Modal.confirm({
        title: '提示',
        content: '是否登录?',
        onOk: () => {
          resolve(true);
        }
      });
    });
  }

  /**
   *
   * @param result 后端接口返回的数据
   *
   * 用来处理「登录」接口调用后的逻辑,可以修改后端返回的错误文案,也可以自定义
   *
   * 只有return true,才会执行默认的跳转事件
   */
  public afterClick(result): Promise<any | null | undefined> {
     // if(result.redirect) {
    // 自定义跳转
         //return false
     //}

    if (result.errorCode === 20060023) {
      result.errorMsg = '手机号不对,请联系管理员';
    }

    return result;
  }
}

Oinone社区 作者:oinone原创文章,如若转载,请注明出处:https://doc.oinone.top/frontend/71.html

访问Oinone官网:https://www.oinone.top获取数式Oinone低代码应用平台体验

(0)
oinone的头像oinone
上一篇 2023年6月20日 下午4:07
下一篇 2023年11月2日 下午1:58

相关推荐

  • 前端-如何修改指定页面的内组件的css样式

    为组件加自定义class,用该class作为父选择器写特定的css样式 以form为例,自定义了以下class <view/>标签的表单视图(FormView)组件 <element/>标签的form(FormWidget)组件 <element/>标签的actionBar(ActionBarWidget)组件 impor…

    2024年6月17日
    15400
  • 默认布局模板(v4)

    默认布局 表格视图(TABLE) <view type="TABLE"> <pack widget="group"> <view type="SEARCH"> <element widget="search" slot="sea…

    2023年11月1日
    6100
  • 创建与编辑一体化

    在业务操作中,用户通常期望能够在创建页面后立即进行编辑,以减少频繁切换页面的步骤。我们可以充分利用Oinone平台提供的创建与编辑一体化功能,使操作更加高效便捷。 通过拖拽实现表单页面设计 在界面设计器中,我们首先需要设计出对应的页面。完成页面设计后,将需要的动作拖入设计好的页面。这个动作的关键在于支持一个功能,即根据前端传入的数据是否包含id来判断是创建操…

    2023年11月21日
    18200
  • 前端打包文件上传到oss

    打包dist文件上传到oss教程 1: 确保boot工程里面安装了「webpack-aliyun-oss」依赖, 如果没有安装,可以手动安装下 2: package.json -> devDependencies -> {"webpack-aliyun-oss": "0.5.2"} 3: 在vue.conf…

    2023年11月1日
    2500
  • 如果让表单支持单选 ?

    本文将介绍在代码和XML配置中的修改,支持表格的单选功能。 先自定义一个widget,继承平台默认的table @SPI.ClassFactory( BaseElementWidget.Token({ viewType: ViewType.Table, widget: 'MyRadioTable' }) ) export class My…

    2023年11月27日
    3600

发表回复

登录后才能评论