当前位置: 首页 > news >正文

网站的积分系统怎么做常州免费网站建站模板

网站的积分系统怎么做,常州免费网站建站模板,做景观园林的网站是,重庆房地产网站建设文章目录 前言Button组件1. 功能分析2. 代码注释说明3. 使用方式4. 效果展示(1)有加载动画,执行promise函数(2)无加载动画,执行click事件 总结 前言 今天这篇主要讲全局按钮组件封装,可根据UI设…

文章目录

  • 前言
  • Button组件
    • 1. 功能分析
    • 2. 代码+注释说明
    • 3. 使用方式
    • 4. 效果展示
    • (1)有加载动画,执行promise函数
    • (2)无加载动画,执行click事件
  • 总结


前言

今天这篇主要讲全局按钮组件封装,可根据UI设计师要求自定义修改。


Button组件

1. 功能分析

(1)可以通过className属性自定义按钮样式,传递样式类名来修改按钮的样式
(2)是否可点击由disabled属性控制,当disabled为true时,按钮被禁用
(3)加载状态由loading属性控制,当loading为true时,按钮显示加载动画
(4)当点击事件回调是Promise函数,执行后续处理;否则直接调用click点击事件

2. 代码+注释说明

// @/components/Button/index.tsx
import { useState } from "react";
import classNames from "classnames";
import styles from "./index.module.scss";// 组件的属性类型
type Props = {// 按钮的文本text: string;// 自定义的类名className?: string;// 是否禁用按钮disabled?: boolean;// 是否显示加载动画loading?: boolean;// 点击按钮时的回调函数click?: () => void;beforeChange?: (() => Promise<any>) | undefined;
};// 按钮组件
export default (props: Props) => {// 解构属性const { text, className, disabled, loading, beforeChange, click } = props;const [load, setLoad] = useState(false);/*** 点击按钮时的事件处理函数* - 如果按钮被禁用,则直接返回* - 如果 beforeChange 是一个Promise函数,则调用其后续处理* - 否则直接调用 click*/const handleClick = () => {if (disabled) return undefined;const isFunction = Object.prototype.toString.call(beforeChange) === "[object Function]";if (!isFunction) {click?.();return false;}// 启用加载动画setLoad(true);beforeChange?.().finally(() => setLoad(false));};return (// 按钮元素<buttontype="button"// 设置类名className={classNames(styles.container,// 禁用或加载时增加特定的类名(disabled || loading) && styles.isDisabled,className)}// 禁用时禁用快捷键操作onKeyDown={handleClick}// 禁用时禁用点击事件onClick={handleClick}>{/* 加载动画 */}{loading && load && <i className={`${styles.loading} iconfont icon-loading`}></i>}{/* 按钮文本 */}<span>{text}</span></button>);
};
------------------------------------------------------------------------------
// @/components/Button/index.module.scss
.container {display: flex;align-items: center;justify-content: center;width: 100%;height: 40px;color: #fff;background-color: var(--cd-primary-color);border-radius: 4px;border: none;cursor: pointer;span {font-size: 14px;line-height: 14px;}&:hover {background-color: var(--cd-primary-color);}.isDisabled {opacity: 0.5;cursor: not-allowed;}@keyframes rotate {0% {transform: rotate(0deg);}50% {transform: rotate(180deg);}100% {transform: rotate(360deg);}}.loading {font-size: 24px;animation: rotate 2s linear infinite;}
}

3. 使用方式

// 引入组件
import Button from "@/components/Button";
// 有加载动画使用方式
<Button text="有loading" loading={true} beforeChange={onDoneChange}></Button>
// 点击按钮触发loading
const onDoneChange = () => {return new Promise((resolve) => {setTimeout(() => {console.log("onDoneChange");resolve(true);}, 2000);});
};-----------------------------------------------------------------------------------------------------// 无加载动画使用方式
<Button text="有loading" loading={false} beforeChange={onDoneClick}></Button>
// 点击按钮不触发loading
const onDoneClick = () => {console.log("onDoneClick");
};

4. 效果展示

(1)有加载动画,执行promise函数

在这里插入图片描述
在这里插入图片描述

(2)无加载动画,执行click事件

)


总结

下一篇讲【全局模态框Modal组件、公共弹窗Dialog组件封装】。关注本栏目,将实时更新。

http://www.zhongyajixie.com/news/11845.html

相关文章:

  • 奉贤做网站公司西安百度竞价代运营
  • 网站开发 需求谷歌google play官网
  • 企业门户网站主要功能郑州优化公司有哪些
  • 北京通州区住房和城乡建设委员会网站做网站
  • 怎么做网站推广怎么样黑马教育培训官网
  • 免费建立英文网站免费发布信息网站大全
  • 做商城网站的项目背景图片百度seo关键词排名查询
  • 天津智能网站建设找哪家网站推广软件哪个最好
  • 博达网站建设教程网站建设网站定制
  • 网站改版的原因网站seo课设
  • 一个ip做几个网站网络营销策划的方法
  • 10个网站做站群百度推广费用预算表
  • 0317网站建设如何用html制作网页
  • wordpress中控制图片标签南京关键词优化服务
  • 东莞 塑胶 网站建设郑州seo网站排名
  • 文化建设基金管理有限公司网站上海专业排名优化公司
  • 2022年国际国内重大新闻广州seo网站营销
  • 微信微网站是什么格式网球新闻最新消息
  • 免费个人网站源码php软文广告100字
  • 济南开发网站深圳网络营销推广外包
  • 网站建设课程设计网页设计模板图片
  • 西安演出公司网站建设百度云网盘搜索引擎
  • 上海网站建设哪家好新闻头条 今天
  • 2013深圳网站设计公司排名百度地图排名怎么优化
  • 任丘 做网站百度信息流代运营
  • 前端网站重构怎么做郑州网站seo服务
  • 盐城网站建设与网页制作建个网站需要多少钱
  • go语言做的网站快速优化系统
  • 公安网计算机可以作为网站开发吗seo整站网站推广优化排名
  • vs做网站如何发布南京百度关键字优化价格