찾다
위챗 애플릿미니 프로그램 개발WeChat 미니 프로그램의 사용자 정의 모달 대화 상자 예에 대한 자세한 설명

WeChat 미니 프로그램의 사용자 정의 모달 대화 상자 예에 대한 자세한 설명

Sep 12, 2017 am 11:22 AM
대화 상자미니 프로그램사용자 정의

이 글은 WeChat 애플릿 사용자 정의 모달 대화 상자 인스턴스의 관련 정보를 주로 소개합니다. 관심 있는 친구들이 참고할 수 있습니다.

공식 API에서 제공하는 디스플레이 모달 팝업으로 인해 창은 단순히 텍스트만 표시할 수 있습니다. 유연성이 부족하여 대화 상자 내용을 사용자 정의할 수 없으므로 모달 팝업 창의 원리를 기반으로 사용자 정의 모달 대화 상자를 구현했습니다.

wx.showModal(OBJECT)
사용자 정의
모달 대화 상자

관련 파일

interfacewxml
stylewxcss
이벤트 및 방법js

렌더링

인터페이스 code.wxml


<button class="show-btn" bindtap="showDialogBtn">弹窗</button>

<!--弹窗-->
<view class="modal-mask" bindtap="hideModal" catchtouchmove="preventTouchMove" wx:if="{{showModal}}"></view>
<view class="modal-dialog" wx:if="{{showModal}}">
 <view class="modal-title">添加数量</view>
 <view class="modal-content">
 <view class="modal-input">
  <input placeholder-class="input-holder" type="number" maxlength="10" bindinput="inputChange" class="input" placeholder="请输入数量"></input>
 </view>
 </view>
 <view class="modal-footer">
 <view class="btn-cancel" bindtap="onCancel" data-status="cancel">取消</view>
 <view class="btn-confirm" bindtap="onConfirm" data-status="confirm">确定</view>
 </view>
</view>

style.wxss


.show-btn {
 margin-top: 100rpx;
 color: #22cc22;
}

.modal-mask {
 width: 100%;
 height: 100%;
 position: fixed;
 top: 0;
 left: 0;
 background: #000;
 opacity: 0.5;
 overflow: hidden;
 z-index: 9000;
 color: #fff;
}

.modal-dialog {
 width: 540rpx;
 overflow: hidden;
 position: fixed;
 top: 50%;
 left: 0;
 z-index: 9999;
 background: #f9f9f9;
 margin: -180rpx 105rpx;
 border-radius: 36rpx;
}

.modal-title {
 padding-top: 50rpx;
 font-size: 36rpx;
 color: #030303;
 text-align: center;
}

.modal-content {
 padding: 50rpx 32rpx;
}

.modal-input {
 display: flex;
 background: #fff;
 border: 2rpx solid #ddd;
 border-radius: 4rpx;
 font-size: 28rpx;
}


.input {
 width: 100%;
 height: 82rpx;
 font-size: 28rpx;
 line-height: 28rpx;
 padding: 0 20rpx;
 box-sizing: border-box;
 color: #333;
}

input-holder {
 color: #666;
 font-size: 28rpx;
}

.modal-footer {
 display: flex;
 flex-direction: row;
 height: 86rpx;
 border-top: 1px solid #dedede;
 font-size: 34rpx;
 line-height: 86rpx;
}

.btn-cancel {
 width: 50%;
 color: #666;
 text-align: center;
 border-right: 1px solid #dedede;
}

.btn-confirm {
 width: 50%;
 color: #ec5300;
 text-align: center;
}

events andmethods.js


Page({
 data: {
  showModal: false,
 },
 onLoad: function () {
 },
 /**
  * 弹窗
  */
 showDialogBtn: function() {
  this.setData({
  showModal: true
  })
 },
 /**
  * 弹出框蒙层截断touchmove事件
  */
 preventTouchMove: function () {
 },
 /**
  * 隐藏模态对话框
  */
 hideModal: function () {
  this.setData({
  showModal: false
  });
 },
 /**
  * 对话框取消按钮点击事件
  */
 onCancel: function () {
  this.hideModal();
 },
 /**
  * 对话框确认按钮点击事件
  */
 onConfirm: function () {
  this.hideModal();
 }
})

구현 아이디어 해석 및 원리

인터페이스 해석:

작성됨 마스크 레이어 + 팝업 창, 바인딩된 데이터 {{showModal}}을 사용하여 팝업 창의 표시 및 숨기기를 제어합니다

이벤트 및 메서드 해석:
팝업 창 표시 방법:


showDialogBtn: function() {
  this.setData({
  showModal: true
  })
 }

팝업창 사라지게 하는 방법:


hideModal: function () {
  this.setData({
  showModal: false
  });
 }

여기서 특별히 주의할 점이 있는데, 다음 방법입니다.


preventTouchMove: function () {
 }

왜 비어있나요? 방법? wxml 인터페이스와 함께 봐야 하기 때문에 마스크드 뷰에 catchtouchmove="preventTouchMove" 이벤트 바인딩이 있습니다. 이 글을 쓰는 이유는 이벤트의 하향 전송을 차단하고 팝업창 이후 마스크 아래의 인터페이스를 클릭하거나 슬라이드할 수 없도록 하기 위해서입니다. 이렇게 작성하지 않고 메인 인터페이스가 스크롤 가능한 인터페이스라면 생각해보면 팝업창이 뜰 때 사용자가 스크롤 목록을 조작할 수도 있으면 제품 관리자가 찾아올 것 같아요.

3. 스타일 해석: (이 제목에는 코드 블록 식별자가 없지만 여전히 코드 블록처럼 표시됩니다. 이것은 버그입니다!!! - -)

.modal-mask 및 . 모달 대화 스타일 특별한 주의가 필요합니다.

가장 중요한 것은 팝업 창이 상단에 있어야 하고 인터페이스에 의해 차단되어서는 안 됩니다. 그런 다음 마스킹 레이어가 인터페이스를 차단해야 하지만 팝업 창은 차단할 수 없습니다. 따라서 .modal-mask 및 .modal-dialog의 z-index 값에 주의해야 합니다.

위 내용은 WeChat 미니 프로그램의 사용자 정의 모달 대화 상자 예에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

DVWA

DVWA

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

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구