提交 62c13a62 编写于 作者: DCloud-WZF's avatar DCloud-WZF 💬

test(general event): 优化示例及测试

上级 0cf8c2ee
const PAGE_PATH = '/pages/component/general-event/general-event' const PAGE_PATH = '/pages/component/general-event/general-event'
describe('event trigger sequence', () => { describe('event trigger sequence', () => {
const platformInfo = process.env.uniTestPlatformInfo.toLocaleLowerCase()
const isAndroid = platformInfo.startsWith('android')
let page let page
let el
beforeAll(async () => { beforeAll(async () => {
page = await program.navigateTo(PAGE_PATH) page = await program.navigateTo(PAGE_PATH)
await page.waitFor('view') await page.waitFor('view')
el = await page.$('.target')
}) })
it('touch', async () => { it('touch', async () => {
if (process.env.uniTestPlatformInfo.startsWith('android') && !process.env.UNI_AUTOMATOR_APP_WEBVIEW) { if (!process.env.UNI_AUTOMATOR_APP_WEBVIEW) {
const el = await page.$('#touch-target')
await el.touchstart({ await el.touchstart({
touches: [{ touches: [{
identifier: 1, identifier: 1,
pageX: 100, pageX: 101,
pageY: 100, pageY: 101,
clientX: 101,
clientY: 101,
screenX: 101,
screenY: 101
}, ], }, ],
changedTouches: [{ changedTouches: [{
identifier: 1, identifier: 1,
pageX: 100, pageX: 101,
pageY: 100, pageY: 101,
clientX: 101,
clientY: 101,
screenX: 101,
screenY: 101
}, ], }, ],
}) })
const touchStartTouchTargetIdentifier = isAndroid ? '1.0' : '1'
const touchStartTouchTargetValue = isAndroid ? '101.0' : '101'
const touchStartTouchIdentifier = await page.$('#touch-start-touch-identifier')
expect(await touchStartTouchIdentifier.text()).toBe(touchStartTouchTargetIdentifier)
const touchStartTouchPageX = await page.$('#touch-start-touch-page-x')
expect(await touchStartTouchPageX.text()).toBe(touchStartTouchTargetValue)
const touchStartTouchPageY = await page.$('#touch-start-touch-page-y')
expect(await touchStartTouchPageY.text()).toBe(touchStartTouchTargetValue)
const touchStartTouchClientX = await page.$('#touch-start-touch-client-x')
expect(await touchStartTouchClientX.text()).toBe(touchStartTouchTargetValue)
const touchStartTouchClientY = await page.$('#touch-start-touch-client-y')
expect(await touchStartTouchClientY.text()).toBe(touchStartTouchTargetValue)
const touchStartTouchScreenX = await page.$('#touch-start-touch-screen-x')
expect(await touchStartTouchScreenX.text()).toBe(touchStartTouchTargetValue)
const touchStartTouchScreenY = await page.$('#touch-start-touch-screen-y')
expect(await touchStartTouchScreenY.text()).toBe(touchStartTouchTargetValue)
const touchStartChangedTouchIdentifier = await page.$('#touch-start-changed-touch-identifier')
expect(await touchStartChangedTouchIdentifier.text()).toBe(touchStartTouchTargetIdentifier)
const touchStartChangedTouchPageX = await page.$('#touch-start-changed-touch-page-x')
expect(await touchStartChangedTouchPageX.text()).toBe(touchStartTouchTargetValue)
const touchStartChangedTouchPageY = await page.$('#touch-start-changed-touch-page-y')
expect(await touchStartChangedTouchPageY.text()).toBe(touchStartTouchTargetValue)
const touchStartChangedTouchClientX = await page.$('#touch-start-changed-touch-client-x')
expect(await touchStartChangedTouchClientX.text()).toBe(touchStartTouchTargetValue)
const touchStartChangedTouchClientY = await page.$('#touch-start-changed-touch-client-y')
expect(await touchStartChangedTouchClientY.text()).toBe(touchStartTouchTargetValue)
const touchStartChangedTouchScreenX = await page.$('#touch-start-changed-touch-screen-x')
expect(await touchStartChangedTouchScreenX.text()).toBe(touchStartTouchTargetValue)
const touchStartChangedTouchScreenY = await page.$('#touch-start-changed-touch-screen-y')
expect(await touchStartChangedTouchScreenY.text()).toBe(touchStartTouchTargetValue)
await el.touchmove({ await el.touchmove({
touches: [{ touches: [{
identifier: 1, identifier: 1,
pageX: 100, pageX: 102,
pageY: 100, pageY: 102,
}, ], clientX: 102,
clientY: 102,
screenX: 102,
screenY: 102
}],
changedTouches: [{ changedTouches: [{
identifier: 1, identifier: 1,
pageX: 101, pageX: 102,
pageY: 101, pageY: 102,
clientX: 102,
clientY: 102,
screenX: 102,
screenY: 102
}, ], }, ],
}) })
const touchMoveTouchTargetIdentifier = isAndroid ? '1.0' : '1'
const touchMoveTouchTargetValue = isAndroid ? '102.0' : '102'
const touchMoveTouchIdentifier = await page.$('#touch-move-touch-identifier')
expect(await touchMoveTouchIdentifier.text()).toBe(touchMoveTouchTargetIdentifier)
const touchMoveTouchPageX = await page.$('#touch-move-touch-page-x')
expect(await touchMoveTouchPageX.text()).toBe(touchMoveTouchTargetValue)
const touchMoveTouchPageY = await page.$('#touch-move-touch-page-y')
expect(await touchMoveTouchPageY.text()).toBe(touchMoveTouchTargetValue)
const touchMoveTouchClientX = await page.$('#touch-move-touch-client-x')
expect(await touchMoveTouchClientX.text()).toBe(touchMoveTouchTargetValue)
const touchMoveTouchClientY = await page.$('#touch-move-touch-client-y')
expect(await touchMoveTouchClientY.text()).toBe(touchMoveTouchTargetValue)
const touchMoveTouchScreenX = await page.$('#touch-move-touch-screen-x')
expect(await touchMoveTouchScreenX.text()).toBe(touchMoveTouchTargetValue)
const touchMoveTouchScreenY = await page.$('#touch-move-touch-screen-y')
expect(await touchMoveTouchScreenY.text()).toBe(touchMoveTouchTargetValue)
const touchMoveChangedTouchIdentifier = await page.$('#touch-move-changed-touch-identifier')
expect(await touchMoveChangedTouchIdentifier.text()).toBe(touchMoveTouchTargetIdentifier)
const touchMoveChangedTouchPageX = await page.$('#touch-move-changed-touch-page-x')
expect(await touchMoveChangedTouchPageX.text()).toBe(touchMoveTouchTargetValue)
const touchMoveChangedTouchPageY = await page.$('#touch-move-changed-touch-page-y')
expect(await touchMoveChangedTouchPageY.text()).toBe(touchMoveTouchTargetValue)
const touchMoveChangedTouchClientX = await page.$('#touch-move-changed-touch-client-x')
expect(await touchMoveChangedTouchClientX.text()).toBe(touchMoveTouchTargetValue)
const touchMoveChangedTouchClientY = await page.$('#touch-move-changed-touch-client-y')
expect(await touchMoveChangedTouchClientY.text()).toBe(touchMoveTouchTargetValue)
const touchMoveChangedTouchScreenX = await page.$('#touch-move-changed-touch-screen-x')
expect(await touchMoveChangedTouchScreenX.text()).toBe(touchMoveTouchTargetValue)
const touchMoveChangedTouchScreenY = await page.$('#touch-move-changed-touch-screen-y')
expect(await touchMoveChangedTouchScreenY.text()).toBe(touchMoveTouchTargetValue)
await el.touchend({ await el.touchend({
touches: [], touches: [{
identifier: 1,
pageX: 103,
pageY: 103,
clientX: 103,
clientY: 103,
screenX: 103,
screenY: 103
}],
changedTouches: [{ changedTouches: [{
identifier: 1, identifier: 1,
pageX: 101, pageX: 103,
pageY: 101, pageY: 103,
clientX: 103,
clientY: 103,
screenX: 103,
screenY: 103
}, ], }, ],
}) })
const data = await page.data() const touchEndTouchTargetIdentifier = isAndroid ? '1.0' : '1'
expect(data.onTouchStartTime).toBeLessThanOrEqual(data.onTouchMoveTime); const touchEndTouchTargetValue = isAndroid ? '103.0' : '103'
expect(data.onTouchMoveTime).toBeLessThanOrEqual(data.onTouchEndTime); const touchEndTouchIdentifier = await page.$('#touch-end-touch-identifier')
expect(await touchEndTouchIdentifier.text()).toBe(touchEndTouchTargetIdentifier)
const touchEndTouchPageX = await page.$('#touch-end-touch-page-x')
expect(await touchEndTouchPageX.text()).toBe(touchEndTouchTargetValue)
const touchEndTouchPageY = await page.$('#touch-end-touch-page-y')
expect(await touchEndTouchPageY.text()).toBe(touchEndTouchTargetValue)
const touchEndTouchClientX = await page.$('#touch-end-touch-client-x')
expect(await touchEndTouchClientX.text()).toBe(touchEndTouchTargetValue)
const touchEndTouchClientY = await page.$('#touch-end-touch-client-y')
expect(await touchEndTouchClientY.text()).toBe(touchEndTouchTargetValue)
const touchEndTouchScreenX = await page.$('#touch-end-touch-screen-x')
expect(await touchEndTouchScreenX.text()).toBe(touchEndTouchTargetValue)
const touchEndTouchScreenY = await page.$('#touch-end-touch-screen-y')
expect(await touchEndTouchScreenY.text()).toBe(touchEndTouchTargetValue)
const touchEndChangedTouchIdentifier = await page.$('#touch-end-changed-touch-identifier')
expect(await touchEndChangedTouchIdentifier.text()).toBe(touchEndTouchTargetIdentifier)
const touchEndChangedTouchPageX = await page.$('#touch-end-changed-touch-page-x')
expect(await touchEndChangedTouchPageX.text()).toBe(touchEndTouchTargetValue)
const touchEndChangedTouchPageY = await page.$('#touch-end-changed-touch-page-y')
expect(await touchEndChangedTouchPageY.text()).toBe(touchEndTouchTargetValue)
const touchEndChangedTouchClientX = await page.$('#touch-end-changed-touch-client-x')
expect(await touchEndChangedTouchClientX.text()).toBe(touchEndTouchTargetValue)
const touchEndChangedTouchClientY = await page.$('#touch-end-changed-touch-client-y')
expect(await touchEndChangedTouchClientY.text()).toBe(touchEndTouchTargetValue)
const touchEndChangedTouchScreenX = await page.$('#touch-end-changed-touch-screen-x')
expect(await touchEndChangedTouchScreenX.text()).toBe(touchEndTouchTargetValue)
const touchEndChangedTouchScreenY = await page.$('#touch-end-changed-touch-screen-y')
expect(await touchEndChangedTouchScreenY.text()).toBe(touchEndTouchTargetValue)
} }
}) })
it('click', async () => { it('click', async () => {
const el = await page.$('#longpress-target')
await el.tap() await el.tap()
const data = await page.data() const targetX = isAndroid ? '0.0' : '0'
expect(data.onTapTime).toBeLessThanOrEqual(data.onClickTime) const targetY = isAndroid ? '0.0' : '0'
const tapEventX = await page.$('#tap-event-x')
expect(await tapEventX.text()).toBe(targetX)
const tapEventY = await page.$('#tap-event-y')
expect(await tapEventY.text()).toBe(targetY)
const clickEventX = await page.$('#click-event-x')
expect(await clickEventX.text()).toBe(targetX)
const clickEventY = await page.$('#click-event-y')
expect(await clickEventY.text()).toBe(targetY)
}) })
it('longPress', async () => { it('longPress', async () => {
if (process.env.uniTestPlatformInfo.startsWith('android') && !process.env.UNI_AUTOMATOR_APP_WEBVIEW) { if (!process.env.UNI_AUTOMATOR_APP_WEBVIEW) {
const el = await page.$('#longpress-target')
await el.longpress() await el.longpress()
const data = await page.data() const longPressTouchTargetIdentifier = isAndroid ? '1.0' : '1'
expect(data.onLongPressTime).toBeGreaterThan(0) const longPressTouchTargetValue = isAndroid ? '0.0' : '0'
const longPressTouchIdentifier = await page.$('#long-press-touch-identifier')
expect(await longPressTouchIdentifier.text()).toBe(longPressTouchTargetIdentifier)
const longPressTouchPageX = await page.$('#long-press-touch-page-x')
expect(await longPressTouchPageX.text()).toBe(longPressTouchTargetValue)
const longPressTouchPageY = await page.$('#long-press-touch-page-y')
expect(await longPressTouchPageY.text()).toBe(longPressTouchTargetValue)
const longPressTouchClientX = await page.$('#long-press-touch-client-x')
expect(await longPressTouchClientX.text()).toBe(longPressTouchTargetValue)
const longPressTouchClientY = await page.$('#long-press-touch-client-y')
expect(await longPressTouchClientY.text()).toBe(longPressTouchTargetValue)
const longPressTouchScreenX = await page.$('#long-press-touch-screen-x')
expect(await longPressTouchScreenX.text()).toBe(longPressTouchTargetValue)
const longPressTouchScreenY = await page.$('#long-press-touch-screen-y')
expect(await longPressTouchScreenY.text()).toBe(longPressTouchTargetValue)
const longPressChangedTouchIdentifier = await page.$('#long-press-changed-touch-identifier')
expect(await longPressChangedTouchIdentifier.text()).toBe(longPressTouchTargetIdentifier)
const longPressChangedTouchPageX = await page.$('#long-press-changed-touch-page-x')
expect(await longPressChangedTouchPageX.text()).toBe(longPressTouchTargetValue)
const longPressChangedTouchPageY = await page.$('#long-press-changed-touch-page-y')
expect(await longPressChangedTouchPageY.text()).toBe(longPressTouchTargetValue)
const longPressChangedTouchClientX = await page.$('#long-press-changed-touch-client-x')
expect(await longPressChangedTouchClientX.text()).toBe(longPressTouchTargetValue)
const longPressChangedTouchClientY = await page.$('#long-press-changed-touch-client-y')
expect(await longPressChangedTouchClientY.text()).toBe(longPressTouchTargetValue)
const longPressChangedTouchScreenX = await page.$('#long-press-changed-touch-screen-x')
expect(await longPressChangedTouchScreenX.text()).toBe(longPressTouchTargetValue)
const longPressChangedTouchScreenY = await page.$('#long-press-changed-touch-screen-y')
expect(await longPressChangedTouchScreenY.text()).toBe(longPressTouchTargetValue)
} }
}) })
}) })
...@@ -4,25 +4,74 @@ ...@@ -4,25 +4,74 @@
<!-- #endif --> <!-- #endif -->
<page-head title="触摸方块测试相关事件"></page-head> <page-head title="触摸方块测试相关事件"></page-head>
<view class="uni-padding-wrap uni-common-mt container"> <view class="uni-padding-wrap uni-common-mt container">
<view class="target" @touchstart="onTouchStart" @touchcancel="onTouchCancel" @touchmove="onTouchMove" <view class="target" id="touch-target" @touchstart="onTouchStart" @touchcancel="onTouchCancel"
@touchend="onTouchEnd" @tap="onTap" @click="onClick" @longpress="onLongPress"></view> @touchmove="onTouchMove" @touchend="onTouchEnd"></view>
<view class="target" id="longpress-target" @tap="onTap" @click="onClick" @longpress="onLongPress"></view>
<view v-if="touchStartEvent !== null"> <view v-if="touchStartEvent !== null">
<text class="title1">touchStart Event: </text> <text class="title1">touchStart Event: </text>
<text class="title2">touches: </text> <text class="title2">touches: </text>
<template v-for="(touch, index) in touchStartEvent!.touches" :key="index"> <template v-for="(touch, index) in touchStartEvent!.touches" :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="touch-start-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="touch-start-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="touch-start-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="touch-start-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="touch-start-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="touch-start-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="touch-start-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
<text class="title2 uni-common-mt">changedTouches: </text> <text class="title2 uni-common-mt">changedTouches: </text>
<template v-for="(touch, index) in touchStartEvent!.changedTouches" :key="index"> <template v-for="(touch, index) in touchStartEvent!.changedTouches" :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="touch-start-changed-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="touch-start-changed-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="touch-start-changed-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="touch-start-changed-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="touch-start-changed-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="touch-start-changed-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="touch-start-changed-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
</view> </view>
<view v-if="touchCancelEvent !== null"> <view v-if="touchCancelEvent !== null">
...@@ -30,18 +79,66 @@ ...@@ -30,18 +79,66 @@
<text class="title2">touches: </text> <text class="title2">touches: </text>
<template v-for="(touch, index) in touchCancelEvent!.touches" :key="index"> <template v-for="(touch, index) in touchCancelEvent!.touches" :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="touch-cancel-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="touch-cancel-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="touch-cancel-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="touch-cancel-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="touch-cancel-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="touch-cancel-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="touch-cancel-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
<text class="title2 uni-common-mt">changedTouches: </text> <text class="title2 uni-common-mt">changedTouches: </text>
<template v-for="(touch, index) in touchCancelEvent!.changedTouches" :key="index"> <template v-for="(touch, index) in touchCancelEvent!.changedTouches" :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="touch-cancel-changed-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="touch-cancel-changed-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="touch-cancel-changed-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="touch-cancel-changed-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="touch-cancel-changed-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="touch-cancel-changed-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="touch-cancel-changed-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
</view> </view>
<view v-if="touchMoveEvent !== null"> <view v-if="touchMoveEvent !== null">
...@@ -49,67 +146,225 @@ ...@@ -49,67 +146,225 @@
<text class="title2">touches: </text> <text class="title2">touches: </text>
<template v-for="(touch, index) in touchMoveEvent!.touches" :key="index"> <template v-for="(touch, index) in touchMoveEvent!.touches" :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="touch-move-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="touch-move-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="touch-move-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="touch-move-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="touch-move-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="touch-move-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="touch-move-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
<text class="title2 uni-common-mt">changedTouches: </text> <text class="title2 uni-common-mt">changedTouches: </text>
<template v-for="(touch, index) in touchMoveEvent!.changedTouches" :key="index"> <template v-for="(touch, index) in touchMoveEvent!.changedTouches" :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="touch-move-changed-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="touch-move-changed-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="touch-move-changed-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="touch-move-changed-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="touch-move-changed-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="touch-move-changed-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="touch-move-changed-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
</view> </view>
<view v-if="longPressEvent !== null"> <view v-if="touchEndEvent !== null">
<text class="title1">longPress Event: </text> <text class="title1">touchEnd Event: </text>
<text class="title2">touches: </text> <text class="title2">touches: </text>
<template v-if="longPressEvent!.touches.length > 0" v-for="(touch, index) in longPressEvent!.touches" <template v-if="touchEndEvent!.touches.length > 0" v-for="(touch, index) in touchEndEvent!.touches"
:key="index"> :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="touch-end-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="touch-end-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="touch-end-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="touch-end-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="touch-end-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="touch-end-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="touch-end-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
<text class="title2 uni-common-mt">changedTouches: </text> <text class="title2 uni-common-mt">changedTouches: </text>
<template v-for="(touch, index) in longPressEvent!.changedTouches" :key="index"> <template v-for="(touch, index) in touchEndEvent!.changedTouches" :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="touch-end-changed-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="touch-end-changed-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="touch-end-changed-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="touch-end-changed-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="touch-end-changed-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="touch-end-changed-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="touch-end-changed-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
</view> </view>
<view v-if="touchEndEvent !== null"> <view v-if="longPressEvent !== null">
<text class="title1">touchEnd Event: </text> <text class="title1">longPress Event: </text>
<text class="title2">touches: </text> <text class="title2">touches: </text>
<template v-if="touchEndEvent!.touches.length > 0" v-for="(touch, index) in touchEndEvent!.touches" <template v-if="longPressEvent!.touches.length > 0" v-for="(touch, index) in longPressEvent!.touches"
:key="index"> :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="long-press-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="long-press-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="long-press-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="long-press-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="long-press-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="long-press-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="long-press-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
<text class="title2 uni-common-mt">changedTouches: </text> <text class="title2 uni-common-mt">changedTouches: </text>
<template v-for="(touch, index) in touchEndEvent!.changedTouches" :key="index"> <template v-for="(touch, index) in longPressEvent!.changedTouches" :key="index">
<text class="title3">touch[{{ index }}]:</text> <text class="title3">touch[{{ index }}]:</text>
<text>identifier: {{touch.identifier}}</text> <view class="uni-list-cell">
<text>pageX: {{ touch.pageX }}, pageY: {{ touch.pageY }}</text> <text>identifier: </text>
<text>clientX: {{ touch.clientX }}, clientY: {{ touch.clientY }}</text> <text id="long-press-changed-touch-identifier">{{touch.identifier}}</text>
<text>screenX: {{ touch.screenX }}, screenY: {{ touch.screenY }}</text> </view>
<view class="uni-list-cell">
<text>pageX: </text>
<text id="long-press-changed-touch-page-x">{{ touch.pageX }}</text>
</view>
<view class="uni-list-cell">
<text>pageY: </text>
<text id="long-press-changed-touch-page-y">{{ touch.pageY }}</text>
</view>
<view class="uni-list-cell">
<text>clientX: </text>
<text id="long-press-changed-touch-client-x">{{ touch.clientX }}</text>
</view>
<view class="uni-list-cell">
<text>clientY: </text>
<text id="long-press-changed-touch-client-y">{{ touch.clientY }}</text>
</view>
<view class="uni-list-cell">
<text>screenX: </text>
<text id="long-press-changed-touch-screen-x">{{ touch.screenX }}</text>
</view>
<view class="uni-list-cell">
<text>screenY: </text>
<text id="long-press-changed-touch-screen-y">{{ touch.screenY }}</text>
</view>
</template> </template>
</view> </view>
<view v-if="tapEvent !== null"> <view v-if="tapEvent !== null">
<text class="title1">tap Event: </text> <text class="title1">tap Event: </text>
<text>x: {{ tapEvent!.x }}, y: {{ tapEvent!.y }}</text> <view class="uni-list-cell">
<text>x: </text>
<text id="tap-event-x">{{ tapEvent!.x }}</text>
</view>
<view class="uni-list-cell">
<text>y: </text>
<text id="tap-event-y">{{ tapEvent!.y }}</text>
</view>
</view> </view>
<view v-if="clickEvent !== null"> <view v-if="clickEvent !== null">
<text class="title1">click Event: </text> <text class="title1">click Event: </text>
<text>x: {{ clickEvent!.x }}, y: {{ clickEvent!.y }}</text> <view class="uni-list-cell">
<text>x: </text>
<text id="click-event-x">{{ clickEvent!.x }}</text>
</view>
<view class="uni-list-cell">
<text>y: </text>
<text id="click-event-y">{{ clickEvent!.y }}</text>
</view>
</view> </view>
</view> </view>
<!-- #ifdef APP --> <!-- #ifdef APP -->
...@@ -121,26 +376,19 @@ ...@@ -121,26 +376,19 @@
data() { data() {
return { return {
title: 'general-event', title: 'general-event',
onTouchStartTime: 0,
touchStartEvent: null as TouchEvent | null, touchStartEvent: null as TouchEvent | null,
touchCancelEvent: null as TouchEvent | null, touchCancelEvent: null as TouchEvent | null,
onTouchMoveTime: 0,
touchMoveEvent: null as TouchEvent | null, touchMoveEvent: null as TouchEvent | null,
onTouchEndTime: 0,
longPressEvent: null as TouchEvent | null, longPressEvent: null as TouchEvent | null,
touchEndEvent: null as TouchEvent | null, touchEndEvent: null as TouchEvent | null,
onTapTime: 0,
tapEvent: null as PointerEvent | null, tapEvent: null as PointerEvent | null,
onClickTime: 0,
clickEvent: null as PointerEvent | null, clickEvent: null as PointerEvent | null,
onLongPressTime: 0,
} }
}, },
methods: { methods: {
onTouchStart(e : TouchEvent) { onTouchStart(e : TouchEvent) {
this.touchStartEvent = e this.touchStartEvent = e
this.onTouchStartTime = Date.now() console.log('onTouchStart', e)
console.log('onTouchStart')
}, },
onTouchCancel(e : TouchEvent) { onTouchCancel(e : TouchEvent) {
this.touchCancelEvent = e this.touchCancelEvent = e
...@@ -148,28 +396,23 @@ ...@@ -148,28 +396,23 @@
}, },
onTouchMove(e : TouchEvent) { onTouchMove(e : TouchEvent) {
this.touchMoveEvent = e this.touchMoveEvent = e
this.onTouchMoveTime = Date.now() console.log('onTouchMove', e)
console.log('onTouchMove')
}, },
onLongPress(e : TouchEvent) { onLongPress(e : TouchEvent) {
this.longPressEvent = e this.longPressEvent = e
this.onLongPressTime = Date.now() console.log('onLongPress', e)
console.log('onLongPress')
}, },
onTouchEnd(e : TouchEvent) { onTouchEnd(e : TouchEvent) {
this.touchEndEvent = e this.touchEndEvent = e
this.onTouchEndTime = Date.now() console.log('onTouchEnd', e)
console.log('onTouchEnd')
}, },
onTap(e : PointerEvent) { onTap(e : PointerEvent) {
this.tapEvent = e this.tapEvent = e
this.onTapTime = Date.now() console.log('onTap', e)
console.log('onTap')
}, },
onClick(e : PointerEvent) { onClick(e : PointerEvent) {
this.clickEvent = e this.clickEvent = e
this.onClickTime = Date.now() console.log('onClick', e)
console.log('onClick')
}, },
}, },
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册