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

网站的积分系统怎么做拉新推广怎么快速拉人

网站的积分系统怎么做,拉新推广怎么快速拉人,wordpress 随机显示文章,flask网站开发视频文章目录 前言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.hrbkazy.com/news/17934.html

相关文章:

  • php 新闻网站开发东莞seo网站优化排名
  • wordpress国外插件速度慢seo首页网站
  • 网站别人做的我自己怎么续费淄博网站seo
  • 哪家做网站好 成都哈尔滨企业网站模板建站
  • 网站开发设计报告书怎么写点击seo软件
  • 中小企业网络拓扑图seo标题优化导师咨询
  • 网站建设框架都有哪些内容seo优化公司排名
  • wordpress nginx 伪静态规则seo公司厦门
  • 小红书的网站建设网站搜索排优化怎么做
  • 广东网站建设公司报价表网站需要怎么优化比较好
  • 宿州建设企业网站公司营销渠道策划方案
  • wordpress评论qq头像seo排名优化课程
  • 2017年做网站多少钱建立网站要多少钱一年
  • 朝阳公司做网站网络市场的四大特点
  • 做国内网站多少钱友情链接有哪些作用
  • 推荐个网站好吗关键词推广工具
  • 全屋定制怎么样做网站友情链接获取的途径有哪些
  • 做网站已经不行企业网站营销的优缺点
  • 网站制作软件都是什么亚马逊关键词排名查询工具
  • 东莞网站开发推荐做手机关键词快速排名软件
  • 好医生网站怎么做不了题目了百度站长管理平台
  • 樟木头镇网站仿做手机百度高级搜索入口
  • 天津建设工程信息网怎么报名的淘宝seo优化是什么
  • WordPress渗透思路上海网站营销seo方案
  • wordpress表白墙模板seo指的是搜索引擎
  • WordPress老文章提示北京seo公司wyhseo
  • 南山做棋牌网站建设成都排名推广
  • 盈利性网站的步骤好用搜索引擎排名
  • 做微信公众号必备的网站西安网络推广公司大全
  • 美食分享网站设计2022最新国内新闻50条简短