다른 테이블의 기본 양식에서 관련 테이블 레코드 편집

Power Apps 내의 테이블 양식에서 관련 테이블 레코드로 작업할 수 있는 여러 방법이 있습니다. 예를 들어 빠른 보기 양식을 사용하여 읽기 전용 모드로 관련 테이블을 포함하고 대화에서 기본 양식을 사용하여 레코드를 만들거나 편집할 수 있습니다.

관련 테이블 레코드로 작업할 수 있는 또 다른 방법은 form component 컨트롤을 다른 테이블의 기본 양식에 추가하는 것입니다. form component 컨트롤을 사용하면 사용자는 다른 테이블의 양식에서 직접 관련 테이블 레코드의 정보를 편집할 수 있습니다.

예를 들어, 다음은 기본 계정 양식의 별도 탭에 있는 양식 구성 요소로, 사용자가 계정 양식을 벗어나지 않고도 연락처 레코드를 편집할 수 있습니다.

별도의 탭에 추가된 Form component 컨트롤.

예를 들어 다음은 기본 계정 양식의 기존 탭에 있는 양식 구성 요소이며, 사용자가 계정 양식 요약 탭에서 나가지 않고 연락처 레코드를 편집할 수도 있습니다.

기존 탭에 추가된 Form component 컨트롤.

테이블 기본 양식에 양식 구성 요소 추가

  1. 왼쪽 탐색 창에서 구성 요소를 선택합니다. 항목이 측면 패널 창을 경우 ...자세히를 선택한 다음 원하는 항목을 선택하세요.
  2. 입력 또는 디스플레이를 확장한 다음 양식을 선택합니다. 양식 구성 요소 컨트롤 구성 페이지에서 컨트롤의 속성을 선택합니다.
    • 양식에 대한 조회 열을 선택합니다.
    • 관련 양식을 선택합니다. 열에 대한 관련 테이블 구성에 따라:
      • 열이 단일 테이블(예: 만든 사람 열)에 연결된 경우 사용할 관련 양식을 선택합니다. 단일 관련 테이블에 대한 양식 구성 요소 컨트롤 추가
      • 열이 여러 테이블(소유자 열과 같은 다형성)에 연결된 경우 + 관련 양식을 선택한 다음 추가를 선택하여 관련 양식을 추가합니다. 계속해서 + 관련 양식 > 추가를 선택하여 각 관련 테이블에 대한 관련 양식을 추가합니다. 여러 관련 테이블에 대한 양식 구성 요소 추가
    • 기본적으로 모든 클라이언트 앱 유형 , 전화태블릿은 양식을 표시할 수 있습니다. 양식을 표시하지 않으려는 클라이언트 유형을 지웁니다.
  3. 완료를 선택합니다.
  4. 저장한 다음 양식을 게시합니다.

클래식 환경을 사용하여 양식 구성 요소 추가

이 예에서 연락처 표준 기본 양식은 계정 기본 양식에 추가된 form component 컨트롤에 대해 구성됩니다.

중요

양식 구성 요소 컨트롤을 추가하는 방법이 변경되었습니다. 최신 환경을 사용하는 것이 좋습니다. 추가 정보: 테이블 기본 양식에 양식 구성 요소 추가

  1. Power Apps에 로그인합니다.

  2. 왼쪽 창에서 테이블을 선택합니다. 또는 솔루션을 연 다음 계정과 같은 테이블을 선택합니다. 항목이 측면 패널 창을 경우 ...자세히를 선택한 다음 원하는 항목을 선택하세요.

  3. 구성 요소 메뉴에서 양식을 선택합니다.

  4. 사용 가능한 양식에서 기본 양식 유형의 양식을 선택합니다.

  5. 클래식으로 전환을 선택합니다. 클래식 양식 편집기 인터페이스는 브라우저에서 탭으로 열립니다.

  6. 삽입 탭을 선택합니다. 그런 다음 새 탭을 만들고 새 섹션을 추가하거나 기존 탭에 새 섹션을 추가합니다.

  7. 새 섹션에서 주요 연락처 조회 열과 같은 조회 열을 추가합니다.

  8. 조회 열을 선택한 다음 탭에서 속성 변경을 선택합니다.

  9. 컨트롤 탭에서, 컨트롤 추가를 선택하고, 컨트롤 유형 목록에서 Form component 컨트롤을 선택한 다음 추가를 선택합니다.

    Form component 컨트롤 선택.

  10. 구성 요소로 , 태블릿전화를 선택합니다.

  11. 편집(연필 아이콘)을 선택하고 속성 구성 대화 상자에서 고정값에 결합을 선택한 다음, 다음과 유사한 XML 항목을 추가합니다. 여기서 TableName는 테이블 고유 이름이며 FormID<QuickForms><QuickFormIds><QuickFormId entityname="TableName">FormID</QuickFormId></QuickFormIds></QuickForms>과 같은 기본 양식의 양식 ID입니다.

    • 예를 들어, 계정 양식에서 연락처기본 양식을 렌더링하려면 <QuickForms><QuickFormIds><QuickFormId entityname="contact">1fed44d1-ae68-4a41-bd2b-f13acac4acfa</QuickFormId></QuickFormIds></QuickForms>을 사용하십시오.

    form component 컨트롤 구성.

  12. 확인을 선택한 후, 다시 확인을 선택합니다.

  13. 저장한 다음 양식을 게시합니다.

테이블의 고유 한 이름을 찾으려면 Power Apps에서 테이블을 선택한 다음 설정을 선택합니다. 이름편집 테이블 창에 나타납니다. 양식 ID는 양식을 편집할 때 브라우저 URL에서 찾을 수 있습니다. ID는 URL의 /편집/ 부분을 따릅니다. 양식 ID는 최신 양식 디자이너의 양식을 열 때 브라우저 URL에서 찾을 수 있습니다.

클래식 양식 디자이너에서 양식 ID는 URL의 formId%3d 부분을 따릅니다.

양식 구성 요소 동작

이 섹션에서는 모델 기반 앱에서 사용하는 경우 양식 구성 요소 동작을 설명합니다.

레코드 선택

form component 컨트롤이 양식을 표시하려면 바인딩된 조회 열에 값이 있어야 합니다. 그렇지 않으면 컨트롤에 메시지 소스 레코드가 선택되지 않았습니다가 표시됩니다. 값을 설정하는 한 가지 방법은 form component 컨트롤과 동일한 조회 열에 바인딩된 조회 컨트롤을 양식에 추가하는 것입니다. lookup 컨트롤을 사용하여 조회 열 값을 변경하면, form component 컨트롤에 새 조회 열 값에 대한 데이터가 포함된 양식이 표시됩니다.

열 유효성 검사

기본 양식과 form component 컨트롤의 모든 열은 Microsoft Dataverse로 데이터를 보내려면 유효해야 합니다. 이는 열 유효성 검사 오류, 필수 열 누락 등 모두에 해당됩니다.

OnSave 처리기는 기본 양식과 form component 컨트롤에 대해 실행됩니다. 모든 처리기는 preventDefault를 사용하여 기본 양식 및 form component 컨트롤에 대한 저장을 취소할 수 있습니다. 이는 데이터를 Dataverse로 보내기 위해 어떤 저장 작업도 preventDefault를 호출할 수 없다는 의미입니다. OnSave 처리기가 호출되는 순서는 정의되어 있지 않습니다. 추가 정보: 모델 기반 앱의 Form OnSave 이벤트(클라이언트 API 참조)

레코드 저장

유효성 검사 단계를 통과하면 각 레코드에 대한 데이터가 Dataverse로 전송됩니다. 현재 각 레코드는 다른 요청을 통해 독립적으로 업데이트됩니다. 저장은 트랜잭션이 아니며 저장 순서는 정의되지 않습니다. 하나의 양식 구성 요소를 저장하는 동안 오류가 발생해도 기본 양식 또는 다른 양식 구성 요소의 변경 사항은 롤백하지 않습니다. 각 저장이 완료되면 양식의 모든 레코드에 대한 데이터가 새로 고쳐집니다.

알림

양식 구성 요소의 알림은 기본 양식의 알림으로 집계됩니다. 예를 들어, 양식 구성 요소에 유효하지 않은 열이 있고 저장하려고 하면 유효하지 않은 열 알림이 양식 구성 요소가 아닌 기본 양식 상단에 나타납니다.

오류 처리

저장 중에 여러 오류가 발생하면 사용자에게 하나의 오류만 표시됩니다. 사용자가 첫 번째 오류를 수정하고 저장하면 다음 오류가 표시됩니다. 사용자는 모든 오류가 해결될 때까지 계속 저장해야 합니다.

저장되지 않은 변경 사항이 있는 레코드 변경

양식 구성 요소의 양식에 저장되지 않은 변경 사항이 있고 사용자가 양식 구성 요소가 결합된 조회 열을 변경하려고 하면 이 변경 사항에 대한 경고가 표시됩니다.

클라이언트 API

양식 컨텍스트은 form component 컨트롤에 사용할 수 있습니다. getControl와 같은 API를 통해 컨트롤에 액세스하여 기본 양식의 양식 컨텍스트를 통해 액세스할 수 있습니다. form component 컨트롤의 관련 테이블에 대한 데이터에 액세스하기 전에 이벤트 핸들러는 isLoaded API에서 컨트롤이 true를 반환할 때까지 기다려야 합니다.

제한 사항

form component 컨트롤을 테이블 양식에 추가하는 경우 다음 제한 사항에 유의하십시오.

  • form component 컨트롤은 기본 양식 렌더링만 지원합니다. 마찬가지로 form component 컨트롤 추가는 기본 양식에서만 지원됩니다. 빨리 만들기, 빨리 보기 및 카드와 같은 다른 양식 유형은 지원되지 않습니다.

  • 비즈니스 프로세스 흐름이 포함된 양식은 현재 기본 테이블 양식 또는 관련 테이블 양식에서 지원되지 않습니다. 비즈니스 프로세스 흐름이 있는 양식이 있는 경우 예상치 못한 동작이 발생할 수 있습니다. 비즈니스 프로세스 흐름을 사용하는 양식에는 양식 구성 요소를 사용하지 않는 것을 권장합니다.

  • form component 컨트롤은 form component 컨트롤에서 사용하는 양식에 form component 컨트롤을 추가하는 등의 포함된 form component 컨트롤을 지원하지 않습니다.

  • 양식 구성 요소 컨트롤은 내장 캔버스 앱을 지원하지 않습니다. 이러한 캔버스 앱에서 예기치 않은 동작이 발생할 수 있습니다.

  • form component 컨트롤은 해당 양식에 여러 탭이 포함된 경우 사용하는 양식의 첫 번째 탭만 표시합니다.

  • 단일 양식의 다른 양식 구성 요소 컨트롤에 대해 동일한 양식을 사용하는 것은 지원되지 않습니다.

  • 양식 구성 요소와 함께 사용하는 양식은 앱에 포함되어야 합니다. 그렇지 않거나 현재 사용자가 양식에 액세스할 수 없으면 앱에 포함되어 있고 사용자가 사용할 수 있는 최상위 기본 양식으로 대체됩니다(양식 순서에 따라).

  • 양식 구성 요소의 양식에서 사용하는 모든 구성 요소는 앱에 포함되어야 합니다. 이러한 구성 요소에는 관련 테이블, 보기 및 비즈니스 프로세스 흐름이 포함됩니다. 그렇지 않으면 양식에서 사용할 수 없거나 예기치 않은 동작이 발생할 수 있습니다.

  • 양식 구성 요소 컨트롤에는 다중 세션 앱에서 렌더링할 때 특정 제한 사항이 있습니다. 클라이언트 API를 사용하여 양식 구성 요소 컨트롤을 수정하거나 양식에 데이터를 입력하는 경우 다중 세션 탭을 전환할 때 변경 사항이 지속되지 않을 수 있습니다.

  • 타임라인 벽을 설정하는 데 사용하는 열이 양식 구성 요소에서 변경되면 타임라인 벽이 업데이트되지 않을 수 있습니다. 페이지가 새로 고쳐지면 시간 표시줄 담벼락이 예상대로 업데이트됩니다.

  • 모바일에서 timeline 컨트롤은 현재 form component 컨트롤에 표시되지 않습니다.

  • 하위 표의 경우 모든 레코드 보기관련 레코드 보기 명령 버튼은 양식 구성 요소 내에서 렌더링되는 경우 사용할 수 없습니다.

  • 대량 편집 대화 상자에서는 Form component 컨트롤이 지원되지 않습니다. 기본적으로 대량 편집 대화 상자의 양식에 나타나지 않으며, 관련 테이블 레코드에 대한 변경 사항은 저장되지 않습니다.

참조 항목

모델 기반 앱 데이터 시각화를 위한 사용자 지정 컨트롤 사용

참고

귀사의 설명서 언어 기본 설정에 대해 말씀해 주시겠습니까? 간단한 설문 조사에 응해주세요. (이 설문 조사는 영어로 되어 있습니다.)

이 설문 조사는 약 7분 정도 걸립니다. 개인 데이터는 수집되지 않습니다(개인정보처리방침).