# Defining Gesture Events
A gesture represents a semantic action (for example, tap, drag, or longpress) that can trigger one or more events. A gesture lifecycle may consist of multiple events from the start to the end of the gesture. Supported events are as follows:
**Touch**
- **touchstart**: Triggered when the touch starts.
- **touchmove**: Triggered when the touch moves.
- **touchcancel**: Triggered when the touch is interrupted, for example, by an incoming call notification or pop-up message.
- **touchend**: Triggered when the touch ends.
**Click**
**click**: Triggered when a user taps the screen quickly.
**Longpress**
**longpress**: Triggered when a user keeps tapping the screen at the same position for a while.
The following is an example:
```html
{{onClick}}
{{touchstart}}
{{touchmove}}
{{touchend}}
{{touchcancel}}
{{onLongPress}}
```
```css
/* xxx.css */
.container {
width: 100%;
height: 100%;
flex-direction: column;
justify-content: center;
align-items: center;
}
.text-container {
margin-top: 30px;
flex-direction: column;
width: 600px;
height: 70px;
background-color: #0000FF;
}
.text-style {
width: 100%;
line-height: 50px;
text-align: center;
font-size: 24px;
color: #ffffff;
}
```
```js
// xxx.js
export default {
data: {
touchstart: 'touchstart',
touchmove: 'touchmove',
touchend: 'touchend',
touchcancel: 'touchcancel',
onClick: 'onclick',
onLongPress: 'onlongpress',
},
touchCancel: function (event) {
this.touchcancel = 'canceled';
},
touchEnd: function(event) {
this.touchend = 'ended';
},
touchMove: function(event) {
this.touchmove = 'moved';
},
touchStart: function(event) {
this.touchstart = 'touched';
},
longPress: function() {
this.onLongPress = 'longpressed';
},
click: function() {
this.onClick = 'clicked';
},
}
```
![en-us_image_00000011](figures/en-us_image_00000011.gif)