찾다
위챗 애플릿미니 프로그램 개발WeChat Mini 프로그램 터치 이벤트 소개

WeChat Mini 프로그램 터치 이벤트 소개

Jun 23, 2018 pm 03:06 PM
이벤트위챗 애플릿

이 글은 위챗 미니 프로그램의 터치 이벤트에 대한 관련 정보를 주로 소개합니다. 위챗 미니 프로그램을 개발할 때 필연적으로 사용하게 될 내용입니다. 여기서는 편집자가 해당 지식을 참고할 수 있도록 도와드립니다.

위챗 미니 프로그램 터치 이벤트:

위챗 미니 프로그램의 '이벤트'는 매우 흥미롭습니다. 문서를 읽은 후 해당 기능이 매우 완벽하고 이벤트가 상위 노드로 전달될 수 있으며 이 이벤트에 인쇄된 정보가 매우 투명하므로 디버깅이 매우 편리하다는 것을 알았습니다.
다음, 여기에 문서를 복사하세요

원본 주소: https://mp.weixin.qq.com/debug/wxadoc/dev/framework/view/wxml/event.html

》》》이벤트란 무엇인가요?

  1. 이벤트는 뷰 레이어에서 로직 레이어로의 통신 방법입니다.

  2. 이벤트는 처리를 위해 사용자 행동을 논리 계층에 피드백할 수 있습니다.

  3. 이벤트는 구성요소에 바인딩될 수 있습니다. 트리거 이벤트에 도달하면 논리 레이어의 해당 이벤트 처리 기능이 실행됩니다.

  4. 이벤트 개체는 ID, 데이터 세트, 터치와 같은 추가 정보를 전달할 수 있습니다.

이벤트 사용 방법

컴포넌트에 이벤트 핸들러 함수를 바인딩합니다.

bindtap과 같이 사용자가 컴포넌트를 클릭하면 해당 페이지의 해당 페이지에서 해당 이벤트 처리 기능을 찾을 수 있습니다.

클릭하세요!

해당 페이지 정의에 해당 이벤트 핸들러 함수를 작성하세요. 매개변수는 이벤트입니다.

Page({ 
 tapName: function(event) { 
 console.log(event) 
 } 
})

로그 정보는 대략 다음과 같은 것을 확인할 수 있습니다.

{ 
"type": "tap", 
"timeStamp": 1252, 
"target": { 
 "id": "tapTest", 
 "offsetLeft": 0, 
 "offsetTop": 0, 
 "dataset": { 
 "hi": "MINA" 
 } 
}, 
"currentTarget": { 
 "id": "tapTest", 
 "offsetLeft": 0, 
 "offsetTop": 0, 
 "dataset": { 
 "hi": "MINA" 
 } 
}, 
"touches": [{ 
 "pageX": 30, 
 "pageY": 12, 
 "clientX": 30, 
 "clientY": 12, 
 "screenX": 112, 
 "screenY": 151 
}], 
"detail": { 
 "x": 30, 
 "y": 12 
} 
}

상세 이벤트 설명

이벤트 분류

이벤트는 버블링으로 구분됩니다. 이벤트 및 비 버블링 이벤트:

버블 이벤트: 구성 요소의 이벤트가 트리거되면 해당 이벤트가 상위 노드로 전달됩니다.

버블링되지 않는 이벤트: 구성 요소의 이벤트가 트리거되면 이벤트가 상위 노드로 전달되지 않습니다.

》》》이벤트 분류

  1. touchstart 손가락 터치

  2. touchmove 터치 후 손가락 이동

  3. touchcancel 팝업창, 전화 수신 알림 등 손가락 터치 동작이 중단됩니다

  4. ㅋㅋㅋ 이벤트 바인딩은 키와 값의 형태로 구성요소의 속성과 동일합니다.
  5. 키는 바인드 또는 캐치로 시작하고 그 뒤에는 바인드탭, 캐치터치스타트
  6. 와 같은 이벤트 유형이 옵니다. 값은 문자열이며, 동일한 이름의 함수가 해당 페이지에 정의되어야 합니다. 그렇지 않으면 이벤트가 트리거될 때 오류가 보고됩니다. 바인드 이벤트 바인딩은 버블링 이벤트가 위쪽으로 버블링되는 것을 방지하지 않으며, 이벤트 잡기 바인딩은 버블링 이벤트가 위쪽으로 버블링되는 것을 방지할 수 있습니다.
  7. 위에서 미니 프로그램 이벤트의 기본 사항을 간략하게 소개했습니다. 이제 "이벤트"의 힘을 보여줄 차례입니다.

클릭(탭)

더블 클릭(dbtap)
  1. 롱 탭. (longtap)
  2. Sliding

Multi-touch
  1. 1. Click
  2. 클릭 이벤트는 touchstart와 touchend로 구성되며, touchend 이후에 tap 이벤트가 발생합니다.
  3. <view>
     <button type="primary" bindtouchstart="mytouchstart" bindtouchend="mytouchend" bindtap="mytap">点我吧</button>
    </view>
    mytouchstart: function(e){ console.log(e.timeStamp + &#39;- touch start&#39;)
    },mytouchend: function(e){ console.log(e.timeStamp + &#39;- touch end&#39;)
    },mytap: function(e){ console.log(e.timeStamp + &#39;- tap&#39;)
    }

  4. 더블클릭

더블클릭 이벤트는 두 번의 클릭 이벤트로 구성되며, 두 번의 클릭 사이의 간격은 300ms 미만이며 위챗 공식으로 간주됩니다. 문서에는 두 번 클릭 이벤트가 없으며 개발자가 정의해야 합니다.

<view>
 <button type="primary" bindtap="mytap">点我吧</button>
</view>

3. 길게 누르기

손가락이 이벤트에 닿은 후 350ms 이상 그대로 둡니다.

<view>
 <button type="primary" bindtouchstart="mytouchstart" bindlongtap="mylongtap" 
 bindtouchend="mytouchend" bindtap="mytap">点我吧</button>
</view>
mytouchstart: function(e){ console.log(e.timeStamp + &#39;- touch start&#39;)
},//长按事件mylongtap: function(e){ console.log(e.timeStamp + &#39;- long tap&#39;)
 },mytouchend: function(e){ console.log(e.timeStamp + &#39;- touch end&#39;)
},mytap: function(e){ console.log(e.timeStamp + &#39;- tap&#39;)
}

클릭, 더블클릭, 길게 누르기 등은 터치 시작, 터치 엔드, 탭 이벤트를 트리거하는 터치 이벤트이므로 터치 취소 이벤트는 실제 기기에서만 시뮬레이션할 수 있습니다. 더 말하지 마세요.


Event트리거 시퀀스

click

touchstart → touchend → tap

더블클릭

touchstart → touchend → tap → touchstart → touchend → tap

터치스타트 → 길게 누르기 → 터치엔드 → 탭

4.滑动

手指触摸屏幕并移动,为了简化起见,下面以水平滑动和垂直滑动为例。 滑动事件由touchstart、touchmove、touchend组成

 

坐标图:

 

  1. 以屏幕左上角为原点建立直角坐标系。第四象限为手机屏幕,Y轴越往下坐标值越大(注意跟数学象限的区别)。

  2. 假设A点为touchstart事件触摸点,坐标为A(ax,ay),然后手指向上滑动到点B(bx,by),就满足条件by

  3. 同理,向右滑动到C(cx,cy),满足cx > ax;向下滑动到D(dx,dy),满足dy > ay;向左移动到E(ex,ey)满足ex

  4. 计算线段AB在Y轴上投影长度为m,在X轴上的投影长度为n

  5. 计算r = m/n,如果r > 1,视为向上滑动。

  6. 同理计算线段AC,AD,AE在Y轴投影长度与X轴的投影长度之比,得出向右向下向左的滑动。

以上没考虑r为1的情况。

<view>
 <button type="primary" bindtouchstart="mytouchstart" bindtouchmove="mytouchmove">点我吧</button>
</view>


5.多点触控

由于模拟器尚不支持多点触控,内测开放后,继续补充。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

微信小程序 监听手势滑动切换页面的实现

微信小程序中的onLoad的解析

위 내용은 WeChat Mini 프로그램 터치 이벤트 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.