react抛物线小球实现
.ballFather{
position: absolute;
width: 15px;
height: 15px;
border-radius: 50%;
transition: all 0.5s cubic-bezier(0.52, -0.3, 0.93, 0.54);
z-index:;
}
.ballSon{
width: 15px;
height: 15px;
background: #3190e8;
border-radius: 50%;
transition:all 0.5s linear;
}
import React, { Component } from "react";
import { connect } from "isomorphism-sdk";
import styled, { keyframes, css } from "styled-components";
import {Track,Button} from '@components'
const Wrap = styled.div`
text-align:center;
color:green;
`;
const Btn = styled.div`
position:fixed;
bottom:0;
left:0;
height:100px;
width:100vw;
line-height:100px;
text-align:center;
background:pink;
`
const Ball = styled.div`
height:20px;
width:20px;
background:red;
`
const BigBox= styled.div`
height:68px;
border:1px solid blue;
margin-bottom:40px;
text-align:left;
`
const SmallBox = styled.span`
display:inline-block;
height:50px;
width:160px;
background:grey;
`
const TheBall={
newBall(event,target){
let div=document.createElement('div');
div.className='ballFather';
document.body.appendChild(div);
let sonDiv=document.createElement('div');
sonDiv.className='ballSon'
div.appendChild(sonDiv);
let top=event.target.getBoundingClientRect().top;
let left=event.target.getBoundingClientRect().left;
div.style.left=left+'px';
div.style.top=top+'px';
let y = (document.documentElement.clientHeight - top +100);//加100是为了防止掉不下去
let x = (document.documentElement.clientWidth+7.5-left)
// debugger
div.style.display ='';
const clientWidth = document.documentElement.clientWidth;
const clientHeight = document.documentElement.clientHeight;
div.style.transform = `translate3d(0,${y}px,0)`;
sonDiv.style.transform = `translate3d(${x/2}px,0,0)`;
setTimeout(()=>{
document.body.removeChild(div);
},500)
}
}
class App extends Component {
constructor(props) {
super(props);
this.state = {
aaa:false
};
}
aaa = (event) =>{
TheBall.newBall(event,target)
console.log(123)
}
render() {
const { activity } = this.props;
return (
<Wrap>
<BigBox>
<SmallBox onClick={this.aaa.bind(this,{x:375,y:-50})}> 123</SmallBox>
</BigBox>
<BigBox>
<SmallBox onClick={this.aaa.bind(this)}>0</SmallBox>
</BigBox>
<BigBox></BigBox>
{ /**
<Track type='click' id='12671'>
<Button onClick={this.aaa.bind(this)}>我是一号</Button>
</Track>
<Track>
<Button onClick={this.aaa}>我是二号</Button>
</Track>
<Track>
<Button>我是三号</Button>
</Track>
<Button>我是死号</Button>
**/
}
<Btn className='abs'>O</Btn>
</Wrap>
);
}
}
export default connect(({ location, activity }, tasks) => {
return {
location,
activity
};
})(App);
react抛物线小球实现的更多相关文章
- React-简单通用的抛物线动画
一个简单通用的 React 抛物线动画demo Usage import { parabola } from "./parabola" ... onAnimate = () =&g ...
- 【vue】饿了么项目-goods商品列表页开发
1.flex 属性是 flex-grow.flex-shrink 和 flex-basis 属性的简写属性. flex-grow 一个数字,规定项目将相对于其他灵活的项目进行扩展的量. flex-sh ...
- Vue实现购物小球抛物线
.shop{ position: fixed; top: 300px; left: 40px; } .ball{ position: fixed; left: 32px; bottom: 22px; ...
- vue 2.0 购物车小球抛物线
备注:此项目模仿 饿了吗.我用的是最新的Vue, 视频上的一些写法已经被废弃了. 布局代码 <div class="ball-container"> <trans ...
- 小tips:用java模拟小球做抛物线运动
这几天刚刚学习了java线程,然后跟着书做了几个关于线程的练习,其中有一个练习题是小球动起来.这个相信很简单,只要运用线程就轻松能够实现.然后看到了它的一个课后思考题,怎样让小球做个抛物线运动,这点我 ...
- js 抛物线 笔记备份
var funParabola = function(element, target, options) { /* * 网页模拟现实需要一个比例尺 * 如果按照1像素就是1米来算,显然不合适,因为页面 ...
- Vue.JS React 精彩文章汇总
JavaScript深入系列 [干货] JavaScript数组所有API全解密 [干货] 移动端:页面->手淘互动动效的探索 - IT大咖说 - 大咖干货,不再错过 [扫盲] Jonath ...
- Vue实现购物车小球动画
思路: 1.因页面分组件分的比较细,由图可知是组件5到组件4的联动. 如果利用组件间通信需要 子组件5 -->组件3-->所有组件的父组件-->组件4, 层级略显复杂,所以使用了vu ...
- canvas抛物线运动轨迹
本来是想做一个贝塞尔曲线运动轨迹的 公式太复杂了,懒得算,公式在最后 我先画了一个抛物线,我确定了两个点,起点(0,0),终点(200,200) 用坐标系可算出方程 y=-0.005x^2 现在找出终 ...
随机推荐
- 在 ubuntu18.04 中搭建 Django 开发环境
在Ubuntu 18.04 安装 python3.pip3.pycharm,搭建 Django 开发环境. 1.安装 python3 pip3 sudo apt-get install python3 ...
- !/usr/bin/env python和!/usr/bin/python的区别
脚本语言第一行 作用:文件中代码用指定可执行程序运行 #!/usr/bin/Python 执行脚本时,调用/usr/bin下python解释器 #!/usr/bin/env python 在环境设 ...
- Shadow Properties之美(一)【Microsoft Entity Framework Core随笔】
最近在做公司的项目的时候,开始把部分程序迁移到EF Core,然后有了一些感触,趁着还没忘却,还是先记录下来. EF Core还在成长中,我写这个的时候,版本是2.2.如果对着已有的EF 5/6来说, ...
- ESP32搭建3.ubuntu14.04下搭建esp32开发环境 (10-5)
硬件为乐鑫出品的ESP32一款集成了wifi和蓝牙的集成模块. 1.首先ctrl+alt+t打开终端,sudo -s选择用root权限登陆 . 2. 输入指令:sudo apt-get install ...
- PAT B1020
PAT B1020 解决思路 :贪心法,每次选取单价最高的月饼. 先上一个自己错误的解法 #include <cstdio> #include <algorithm> usin ...
- 谱聚类(Spectral Clustring)原理
谱聚类(spectral clustering)是广泛使用的聚类算法,比起传统的K-Means算法,谱聚类对数据分布的适应性更强,聚类效果也很优秀,同时聚类的计算量也小很多,更加难能可贵的是实现起来也 ...
- python+appium 自动化2--元素定位uiautomatorviewer
出处:https://www.cnblogs.com/yoyoketang/p/6128741.html 前言: 可以打开手机上的app了,下一步元素定位uiautomatorviewer,通过定位到 ...
- win10切换AHCI模式
win10切换AHCI模式 笔记本电脑总是卡卡的,开机好慢,一狠心就买了一个固态硬盘装上.听说电脑开启AHCI模式跟固态硬盘更配哦.所以好好得鼓捣了一下电脑. 保证win10开启了安全模式, 如果没有 ...
- matlab 小波工具箱
wavemenu --- >wavelet ---->wavelet packet1-D Matlab小波工具箱的使用1 转载▼ http://blog.sina.com.cn/s/blo ...
- 爬虫豆瓣top250项目-开发文档
项目托管平台地址:https://github.com/gengwenhao/GetTop250.git 负责内容:1.使用python的request库先获取网页内容下来 2.再使用一个好用的lxm ...