首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用react-spring创建从右向左移动的文本?

如何使用react-spring创建从右向左移动的文本?
EN

Stack Overflow用户
提问于 2019-06-20 19:46:55
回答 2查看 5.1K关注 0票数 0

使用react-spring移动文本动画?

我正在开发一个使用reactjs作为前端的网站,在标题中我想自动从右到左移动一些文本,但我只想用react-spring来动画!有人能解决我的问题吗?

因为我刚接触react-spring,所以我找不到正确的解决方案!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-06-20 22:11:34

React-spring是基于物理的,这种类型的动画并不是它的强项。我会做这样的事情。

代码语言:javascript
复制
import React, { useState } from "react";
import { useSpring, animated } from "react-spring";

const TextScroller = ({ text }) => {
  const [key, setKey] = useState(1);

  const scrolling = useSpring({
    from: { transform: "translate(60%,0)" },
    to: { transform: "translate(-60%,0)" },
    config: { duration: 2000 },
    reset: true,
    //reverse: key % 2 == 0,
    onRest: () => {
      setKey(key + 1);
    }
  });

  return (
    <div key={key}>
      <animated.div style={scrolling}>{text}</animated.div>);
    </div>
  );
};

export default TextScroller;

它有改进的空间。不处理文本长度。可以禁用滚动条。但我给你留了点东西。:)

工作演示:https://codesandbox.io/s/basic-text-scroller-with-react-spring-siszy

票数 2
EN

Stack Overflow用户

发布于 2019-06-20 20:23:06

首先必须将react-spring安装到您的项目中。

在本例中,您可以将代码包含在App.js文件中,如下所示:

代码语言:javascript
复制
import { render } from 'react-dom'
import React, { useState, useCallback } from 'react'
import { useTransition, animated } from 'react-spring'

const pages = [
  ({ style }) => <animated.div style={{ ...style, background: 'lightpink' }}>A</animated.div>,
  ({ style }) => <animated.div style={{ ...style, background: 'lightblue' }}>B</animated.div>,
  ({ style }) => <animated.div style={{ ...style, background: 'lightgreen' }}>C</animated.div>,
]

export default function App() {
  const [index, set] = useState(0)
  const onClick = useCallback(() => set(state => (state + 1) % 3), [])
  const transitions = useTransition(index, p => p, {
    from: { opacity: 0, transform: 'translate3d(100%,0,0)' },
    enter: { opacity: 1, transform: 'translate3d(0%,0,0)' },
    leave: { opacity: 0, transform: 'translate3d(-50%,0,0)' },
  })
  return (
    <div className="simple-trans-main" onClick={onClick}>
      {transitions.map(({ item, props, key }) => {
        const Page = pages[item]
        return <Page key={key} style={props} />
      })}
    </div>
  )
}

render(<App />, document.getElementById('root'))

我希望这对你有用。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56685305

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档