>웹 프론트엔드 >uni-app >유니앱 팝업박스 구현 방법

유니앱 팝업박스 구현 방법

PHPz
PHPz원래의
2023-04-23 16:40:0014050검색

모바일 인터넷의 인기로 인해 점점 더 많은 사람들이 온라인 활동에 스마트폰과 태블릿을 사용하기 시작했습니다. 이와 함께 모바일 앱, 웹 디자인에 대한 수요도 늘어나고 있다. UniApp은 이 문제를 해결하는 크로스 플랫폼 개발 프레임워크로 iOS, Android, H5 및 기타 플랫폼을 포함하되 이에 국한되지 않는 여러 터미널에서 실행되는 코드 세트와 효과를 얻을 수 있는 크로스 플랫폼 개발 솔루션을 제공합니다. .

이 글에서는 주로 UniApp 프레임워크의 팝업 상자에 대해 설명합니다.

UniApp 프레임워크에서 팝업 상자는 일반적으로 사용되는 구성 요소 중 하나입니다. 작업 확인, 사용자 로그인 획득 등 클라이언트에서 팝업 창 형태로 사용자에게 메시지를 표시하는 데 도움이 될 수 있습니다. 정보 등 따라서 UniApp 팝업박스를 구현하는 방법은 우리가 마스터해야 할 기술 중 하나입니다.

1. UniApp 팝업 상자 사용

UniApp 프레임워크는 다양한 요구 사항을 충족하는 데 도움이 되는 두 가지 유형의 팝업 상자를 제공합니다. 기본 사용법 중 하나를 살펴보겠습니다.

  • Alert()를 사용하여 간단한 텍스트 정보 표시

UniApp 프레임워크에서는 Alert() 메서드를 사용하여 사용자에게 간단한 텍스트 정보를 형식으로 표시할 수 있습니다. 팝업창의 내용:

uni.alert({
  title: '提示信息',
  content: '这是一条简单的弹出提示',
  success: function () {
     console.log('弹出框已关闭')
  }
});

그 중 title은 팝업 상자의 제목이고, content는 팝업 상자의 주요 내용이며, 성공은 팝업 상자가 닫힌 후의 콜백 함수입니다. 물론 취소 버튼 콜백 기능도 취소를 통해 구현할 수 있습니다.

  • 사용자 선택을 얻으려면 확인()을 사용하세요

UniApp 프레임워크에서는 확인() 메서드를 사용하여 선택 프롬프트 상자를 팝업할 수도 있습니다. 예:

uni.confirm({
  title: '选择操作',
  content: '你确定要进行某个操作吗?',
  success: function (res) {
    if (res.confirm) {
      console.log('用户点击确认操作');
    } else if (res.cancel) {
      console.log('用户取消操作');
    }
  }
});

위 코드에서 확인( ) 메소드가 팝업됩니다. 사용자가 선택을 완료한 후 콜백 함수를 통해 사용자의 선택을 얻고 선택 결과에 해당하는 작업을 수행하는 선택 프롬프트 상자가 나타납니다. 그 중 res.confirm은 사용자가 작업을 확인했음을 나타내고, res.cancel은 사용자가 작업을 취소했음을 나타냅니다.

2. 사용자 정의된 UniApp 팝업 상자 구현

프레임워크에서 제공하는 내장 메서드를 사용하는 것 외에도 팝업 상자를 사용자 정의하여 보다 유연한 효과를 얻을 수도 있습니다. 이제 사용자 정의 UniApp 팝업 상자를 구현하는 방법을 살펴보겠습니다.

  1. HTML 레이아웃

우선 팝업 상자의 HTML 레이아웃을 준비해야 합니다. 예:

<template>
  <view class="modal">
    <view class="modal-content">
      <view class="modal-header">
        <h2>弹出框标题</h2>
        <i class="fa fa-times" @click="closeModal"></i>
      </view>
      <view class="modal-body">
        <p>这里是弹出框的主体内容</p>
      </view>
      <view class="modal-footer">
        <button type="button" @click="submit">确定</button>
        <button type="button" @click="closeModal">取消</button>
      </view>
    </view>
  </view>
</template>

위 레이아웃에서는 View 구성 요소를 사용하여 다양한 클래스를 통해 다양한 스타일 효과를 얻습니다. 속성을 사용하여 클릭 이벤트를 바인딩하기 위해 @click과 같은 Vue 명령도 사용했습니다.

  1. CSS 스타일

다음으로 팝업 상자의 스타일을 더욱 아름답고 합리적으로 처리해야 합니다. 예를 들면 다음과 같습니다.

.modal {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 99999;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  display: flex;
  justify-content: center;
  align-items: center;
}

.modal .modal-content {
  width: 400rpx;
  background-color: #ffffff;
  border-radius: 10rpx;
  overflow: hidden;
}

.modal .modal-content .modal-header {
  background-color: #337ab7;
  color: #ffffff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10rpx;
}

.modal .modal-content .modal-header h2 {
  margin: 0;
}

.modal .modal-content .modal-header i {
  font-size: 20rpx;
  cursor: pointer;
}

.modal .modal-content .modal-body {
  padding: 20rpx;
}

.modal .modal-content .modal-footer {
  background-color: #eeeeee;
  padding: 10rpx;
  display: flex;
  justify-content: flex-end;
}

.modal .modal-content .modal-footer button {
  border: none;
  padding: 10rpx 20rpx;
  margin-left: 10rpx;
  border-radius: 5rpx;
  cursor: pointer;
}

.modal .modal-content .modal-footer button:first-child {
  background-color: #337ab7;
  color: #ffffff;
}

.modal .modal-content .modal-footer button:last-child {
  background-color: #dddddd;
  color: #333333;
}

위 CSS 스타일에서는 다음과 같은 몇 가지 CSS 기술을 사용했습니다. :after 및 :before와 같은 의사 클래스 식별자는 여러 버튼 그룹의 스타일 효과를 구현하는 동시에 @keyframes와 같은 규칙을 사용하여 애니메이션 효과를 정의합니다.

  1. JS 코드

마지막으로 다음과 같이 팝업 상자의 특정 기능을 구현하는 JS 코드를 작성해야 합니다.

export default {
  data() {
    return {
      visible: false
    }
  },
  methods: {
    showModal() {
      this.visible = true;
    },
    closeModal() {
      this.visible = false;
    },
    submit() {
      console.log('执行提交操作');
      this.closeModal();
    }
  }
}

위 코드에서는 data() 메서드를 사용하여 데이터를 정의합니다. visible 속성은 팝업 상자의 표시 및 닫힘 상태를 저장하는 데 사용됩니다. 동시에 팝업 상자의 표시 및 닫기와 확인 버튼의 클릭 동작을 각각 제어하는 ​​데 사용되는 showModal(), closeModal() 및 submit()의 세 가지 메서드도 정의했습니다.

  1. 페이지 사용

위 단계를 완료한 후 특정 페이지에서 사용자 정의된 팝업 상자를 사용할 수 있습니다. 예:

<template>
  <view>
    <button type="button" @click="showModal">打开弹出框</button>
    <modal :visible.sync="visible"></modal>
  </view>
</template>

<script>
import Modal from '@/components/modal.vue';

export default {
  components: {
    Modal
  },
  data() {
    return {
      visible: false
    }
  },
  methods: {
    showModal() {
      this.visible = true;
    }
  }
}
</script>

위 코드에서는 가져오기를 통해 Vue 구성 요소 작성 방법을 사용합니다. 구문에서 우리가 정의한 Modal 구성 요소가 도입되고 data() 메서드에 visible이라는 데이터 속성도 정의됩니다. 템플릿에서는 버튼 태그의 @click 바인딩 이벤트를 통해 showModal 메서드를 호출하여 팝업 상자를 표시합니다.

3. 요약

이제 UniApp 팝업 상자 사용자 정의 프로세스가 완료되었습니다. 일반적으로 UniApp에서 제공하는 팝업 상자 구성 요소에는 기본적인 요구 사항을 충족할 수 있는 경고() 및 확인()과 같은 메서드가 내장되어 있습니다. 더 복잡한 팝업 상자가 필요한 경우 HTML 레이아웃을 사용할 수 있습니다. CSS 스타일, JS 코드 등 이러한 측면에서 팝업 상자를 사용자 정의하는 효과를 얻을 수 있습니다. 이 글이 모든 분들의 UniApp 개발 작업에 도움이 되기를 바랍니다.

위 내용은 유니앱 팝업박스 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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