【实战】流动的箭头 —— 线性流动组件(repeating-linear-gradient,@keyFrames)

本文主要是介绍【实战】流动的箭头 —— 线性流动组件(repeating-linear-gradient,@keyFrames),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、引子
  • 二、组件思路
  • 三、效果图
  • 四、源代码
    • src\components\flow-arrow\index.js
    • src\components\flow-arrow\keyFrames.js
    • src\components\flow-arrow\constant.js
    • 组件调用
  • 五、拓展学习
    • 1.repeating-linear-gradient
    • 2.animation
    • 3.@keyFrames
  • 组件源码获取:
  • ⭐️ 好书推荐
    • 《Next.js实战》
      • 【内容简介】


一、引子

在大屏数据展示中,若是按节点展示在不同数据层的数据时,为了形象体现数据的流动效果,需要让节点之间,层与层之间用流动的虚线+箭头连接。

二、组件思路

正常情况下,数据需要从上个节点底部出发到下个节点顶部结束,层与层之间传递需要经过汇总。因此水平方向上主要有两种情况:

  • 底部汇总:数据流从外向里;(左侧从左往右,右侧从右往左)
  • 顶部分散:数据流从里向外;(左侧从右往左,右侧从左往右)

偶尔会有特殊情况,比如:

  • 同一层中两个节点数据是互相流动的,这就需要在两个节点之间使用双向箭头,且依据实际情况,其中一个可能不会有向下流动的数据只有与同层节点的数据交互,若此层刚好两个节点且为了美观保持对称(而非将带有向下流动数据的节点居中),此时数据流动会出现从左到右或从右到左的单向流动
  • 同一层中还会有层级关系。。。(这个对数据流影响不大)
  • 此思路在当前需求下够用了,后续有新需求再灵活变动

垂直方向上,无论是节点底部的小尾巴还是顶部的部分都是向下流动,而且由于与节点是强关联的,因此不需要单独封装出来到组件中

效果优化:

  • 为保证起始位置不会出现“闪现”,虚线的出现一定是从 0 到 1 的过程,主要需要调整盒子内虚线在起始位置的偏移度,经过调整,最终确定偏移度最小为线段长度;
  • 为保证动画的流畅性,动画结束时需要与动画开始时状态保持一致,主要调整整段虚线的动画位移距离和线段及之间间隔,最终确定最小位移距离为“线段长度+间隔”

三、效果图

在这里插入图片描述

四、源代码

src\components\flow-arrow\index.js

/* eslint-disable react/no-unknown-property */
/** @jsxRuntime classic */
/** @jsx jsx */
import { jsx } from '@emotion/react';
import keyFrames from './keyFrames'
import constant from './constant'const { flowLen } = constant/*** 线性流动组件* @param direction 方向:从左到右(lr);从右到左(rl);从里到外(io);从外到里(oi)* @param place 位置:顶部(head);底部(foot)* @description 方向和位置参数控制,顶部数据流发散(io),底部数据流汇聚(oi),具体显隐可参考如下(案例中:fo 是顶层;f3 是底层)*   - {floor.code --= 'f0'? null : <div className='flow-head'/>} *   - {floor.code --- 'f3'? null : <div className='flow-foot'/>}*   其他特殊情况特殊处理(单独配置,强制传参改变方向)*/
const containerStyle = {...keyFrames,'.flow-container': {width: 'calc(100% - 24vh)',height: '.5vh',position: 'relative',left:'12.8vh',overflow: 'hidden',},".flow-head-container": {top:'-.6vh',},".flow-foot-container": {bottom:'-1.6vh',},".flow": {width:'110%',height: '.5vh',// 第三个值 每个线段长度; 第四个值角度同向渐变距离; 第五个值 每个线段间隔background: `repeating-linear-gradient(90deg, #e2e8fd 0, #e2e8fd ${flowLen}vh, rgba(0,0,0,0) ${flowLen}vh, rgba(0,0,0,0) ${flowLen}vh)`,zIndex: 1,},'.flow-both-container':{display:'flex',},'.flow-both': {width:'51%',overflow: 'hidden','.flow-rl': {marginLeft: '-2vh'},},'.flow-lr, .flow-rl,.flow-io, .flow-oi': {background: `repeating-linear-gradient(90deg, #e2e8fd 0, #e2e8fd ${flowLen}vh, rgba(0,0,0,0) 0vh, rgba(0,0,0,0) ${flowLen * 2}vh)`,},'.flow-lr': {animation: 'flow-lr linear 1s infinite',marginLeft:'-2vh',},'.flow-rl': {animation: 'flow-rl linear 1s infinite',marginRight: '-2vh',},
}const index = (props = {direction: 'lr', place: 'head'}) => {const { direction, place } = propsreturn <div css={containerStyle}><div className={`flow-container flow-${place}-container`}>{(() => {switch (direction) { case 'lr': case 'rl':return <div className={`flow flow-${props.direction}`} />case 'io':return <div className='flow-both-container'><div className={`flow-both`}><div className={`flow flow-head flow-rl`} /></div><div className={`flow-both`}><div className={`flow flow-lr`} /></div></div>case 'oi':return <div className='flow-both-container'><div className={`flow-both`}><div className={`flow flow-lr`} /></div><div className={`flow-both` }><div className={`flow flow-rl`} /></div></div>default:return <div className={`flow`} />}})()}</div></div>
}export default index

src\components\flow-arrow\keyFrames.js

const keyFrames = {'@keyFrames flow-lr': {from: {transform:'translateX(0vh)',},to: {transform: 'translateX(4.8vh)',}},'@keyFrames flow-rl': {from: {transform:'translateX(4.8vh)',},to: {transform: 'translateX(0vh)',}}
}export default keyFrames

src\components\flow-arrow\constant.js

const constant = {flowLen: 1.2,
}export default constant

组件调用

/* eslint-disable react/no-unknown-property */
/** @jsxRuntime classic */
/** @jsx jsx */
import { jsx } from '@emotion/react';
import FlowArrow from './components/flow-arrow/index'function App() {return (<div className="App" css={{background: '#00f', height: '600px', 'h1': { textAlign: 'center' }}}><h1>左右</h1><FlowArrow direction='lr' place='head'/><h1>右左</h1><FlowArrow direction='rl' place='head'/><h1>内外</h1><FlowArrow direction='io' place='head'/><h1>外内</h1><FlowArrow direction='oi' place='head'/></div>);
}export default App;

五、拓展学习

1.repeating-linear-gradient

官方文档:repeating-linear-gradient() - CSS:层叠样式表 | MDN

2.animation

官方文档:animation - CSS:层叠样式表 | MDN

animation 属性是 animation-nameanimation-duration, animation-timing-functionanimation-delayanimation-iteration-countanimation-directionanimation-fill-modeanimation-play-state 属性的一个简写属性形式。

3.@keyFrames

官方文档:@keyframes - CSS:层叠样式表 | MDN


组件源码获取:

  • 关注公众号:程序边界,输入 ‘程序边界 001’ !
  • 直接下载:流动的箭头-线性流动组件(repeating-linear-gradient,@keyFrames)资源-CSDN文库

⭐️ 好书推荐

《Next.js实战》

在这里插入图片描述

【内容简介】

《Next.js实战》详细阐述了与Next.js框架相关的基本解决方案,主要包括Next.js简介、不同的渲染策略、Next.js基础知识和内建组件、在Next.js中组织代码库和获取数据、在Next.js中管理本地和全局状态、CSS和内建样式化方法、使用UI框架、使用自定义服务器、测试Next.js、与SEO协同工作和性能管理、不同的部署平台、管理身份验证机制和用户会话、利用Next.js和GraphCMS构建电子商务网站等内容。此外,本书还提供了相应的示例、代码,以帮助读者进一步理解相关方案的实现过程。
在这里插入图片描述

📚 京东购买链接:《Next.js实战》
📚 当当购买链接:《Next.js实战》

这篇关于【实战】流动的箭头 —— 线性流动组件(repeating-linear-gradient,@keyFrames)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/151433

相关文章

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

Python实战之屏幕录制功能的实现

《Python实战之屏幕录制功能的实现》屏幕录制,即屏幕捕获,是指将计算机屏幕上的活动记录下来,生成视频文件,本文主要为大家介绍了如何使用Python实现这一功能,希望对大家有所帮助... 目录屏幕录制原理图像捕获音频捕获编码压缩输出保存完整的屏幕录制工具高级功能实时预览增加水印多平台支持屏幕录制原理屏幕

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统

最新Spring Security实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)

《最新SpringSecurity实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)》本章节介绍了如何通过SpringSecurity实现从配置自定义登录页面、表单登录处理逻辑的配置,并简单模拟... 目录前言改造准备开始登录页改造自定义用户名密码登陆成功失败跳转问题自定义登出前后端分离适配方案结语前言

OpenManus本地部署实战亲测有效完全免费(最新推荐)

《OpenManus本地部署实战亲测有效完全免费(最新推荐)》文章介绍了如何在本地部署OpenManus大语言模型,包括环境搭建、LLM编程接口配置和测试步骤,本文给大家讲解的非常详细,感兴趣的朋友一... 目录1.概况2.环境搭建2.1安装miniconda或者anaconda2.2 LLM编程接口配置2

Spring组件初始化扩展点BeanPostProcessor的作用详解

《Spring组件初始化扩展点BeanPostProcessor的作用详解》本文通过实战案例和常见应用场景详细介绍了BeanPostProcessor的使用,并强调了其在Spring扩展中的重要性,感... 目录一、概述二、BeanPostProcessor的作用三、核心方法解析1、postProcessB

kotlin中的行为组件及高级用法

《kotlin中的行为组件及高级用法》Jetpack中的四大行为组件:WorkManager、DataBinding、Coroutines和Lifecycle,分别解决了后台任务调度、数据驱动UI、异... 目录WorkManager工作原理最佳实践Data Binding工作原理进阶技巧Coroutine

基于Canvas的Html5多时区动态时钟实战代码

《基于Canvas的Html5多时区动态时钟实战代码》:本文主要介绍了如何使用Canvas在HTML5上实现一个多时区动态时钟的web展示,通过Canvas的API,可以绘制出6个不同城市的时钟,并且这些时钟可以动态转动,每个时钟上都会标注出对应的24小时制时间,详细内容请阅读本文,希望能对你有所帮助...

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav