Grav-양식

다음을 사용하여 양식을 만들 수 있습니다. form이 링크 에서 사용할 수있는 플러그인 . 양식 플러그인을 검색하여 Grav 폴더에 설치하십시오.

다음 명령을 사용하여이 플러그인을 설치할 수도 있습니다. $ bin/gpm install Form. Grav의 루트 폴더로 이동하여이 명령을 입력하십시오. 양식 플러그인을 자동으로 다운로드하고 필요한 종속성을 설치합니다.

간단한 양식 만들기

YAML frontmatter 페이지에서 정의 할 수있는 간단한 양식을 만들 수 있습니다. 다음은 양식의 예입니다-

---
title: Contact Form

form:
   name: contact

   fields:
      - name: name
         label: Name
         placeholder: Enter your name
         autofocus: on
         autocomplete: on
         type: text
         validate:
            required: true

      - name: email
         label: Email
         placeholder: Enter your email address
         type: email
         validate:
            required: true

      - name: message
         label: Message
         placeholder: Enter your message
         type: textarea
         validate:
            required: true

      - name: g-recaptcha-response
         label: Captcha
         type: captcha
         recatpcha_site_key: 6LelOg4TAAAAALAt1CjjjVMxFLKY8rrnednYVbr8
         recaptcha_not_validated: 'Captcha not valid!'
         validate:
            required: true

   buttons:
      - type: submit
         value: Submit
      - type: reset
         value: Reset

   process:
      - email:
         subject: "[Site Contact Form] {{ form.value.name|e }}"
         body: "{% include 'forms/data.html.twig' %}"
      - save:
         fileprefix: contact-
         dateformat: Ymd-His-u
         extension: txt
         body: "{% include 'forms/data.txt.twig' %}"
      - message: Thank you for getting in touch!
      - display: thankyou
---

위의 코드는 이름, 이메일, 메시지 및 Captcha 필드가있는 간단한 양식 페이지를 보여줍니다. 양식을 작성한 후 정보를 제출하면 양식은 다음을 추가하여 처리됩니다.process 코드에 표시된대로 필드를 YAML frontmatter에 추가합니다.

그만큼 process 필드는 다음 정보를 사용합니다-

  • 그만큼 email 옵션은 다음과 같은 두 개의 필드를 사용합니다. from 필드는 이메일 발신자를 지정하고 to 필드는 메일 수신자를 지정합니다.

  • 그만큼 subject 용도 [feedback][entered mail] 입력 한 이메일로 이메일을 보내는 옵션입니다.

  • 이메일 본문은 forms/data.html.twig 테마 폴더에있는 파일.

  • 양식 입력 데이터는 user/data폴더. 템플릿은forms/data.txt.twig 테마 폴더에있는 파일.

  • 아래에 하위 페이지를 만듭니다. thankyou/ 사용자가 양식을 제출할 때 해당 페이지로 리디렉션되는 하위 폴더.

다음 표와 같이 양식 플러그인으로 일부 필드를 사용할 수 있습니다.

Sr. 아니. 필드 및 설명
1

Captcha

사용자가 인간인지 여부를 확인하기 위해 컴퓨팅에 사용되는 안티 스팸 필드입니다.

2

Checkbox

간단한 체크 박스를 표시합니다.

Checkboxes

여러 확인란이 표시됩니다.

4

Date and Datetime

두 필드 모두 날짜와 날짜를 각각 시간과 함께 표시하는 데 사용됩니다.

5

Email

유효성 검사가 포함 된 이메일 필드입니다.

6

Hidden

숨겨진 필드를 지정합니다.

7

Password

암호 필드를 지정합니다.

8

Radio

간단한 라디오 버튼을 표시합니다.

9

Select

선택 필드를 제공합니다.

10

Spacer

양식에 제목, 텍스트 또는 수평선을 추가 할 수 있습니다.

11

Text

간단한 텍스트 필드를 표시합니다.

12

Textarea

간단한 텍스트 영역 필드를 표시합니다.

13

Display

입력 필드가 아닌 텍스트 또는 지침 필드를 표시합니다.

필드 매개 변수

모든 필드는 양식의 모양을 사용자 정의하는 데 사용할 수있는 다음 매개 변수를 허용합니다.

Sr. 아니. 매개 변수 및 설명
1

label

레이블 필드를 정의합니다.

2

validate.required

필요한 요소를 만듭니다.

validate.pattern

유효성 검사 패턴을 지정합니다.

4

validate.message

유효성 검사가 실패하면 메시지를 표시합니다.

5

type

필드 유형을 정의합니다.

6

default

기본 필드 유형을 정의합니다.

7

size

대형, x- 소형, 중형, 롱, 소형과 같은 필드 크기를 표시합니다.

8

name

필드 이름을 정의합니다.

9

classes

CSS 클래스와 함께 문자열을 사용합니다.

10

id

필드 ID를 정의합니다.

11

style

필드의 스타일을 지정합니다.

12

title

필드의 제목을 정의합니다.

13

disabled

필드가 비활성화 상태인지 여부를 결정합니다.

14

placeholder

사용자가 값을 입력하기 전에 입력 필드에 표시되는 짧은 힌트입니다.

15

autofocus

페이지가로드 될 때 입력 요소가 자동으로 포커스를 받도록 지정합니다.

16

novalidate

제출할 때 양식 데이터의 유효성을 검사하지 않도록 지정합니다.

17

readonly

필드를 읽기 전용 상태로 결정합니다.

18

autocomplete

사용자가 필드에 입력을 시작할 때 필드에 옵션을 표시하고 이전에 입력 한 값을 기반으로 값을 표시합니다.

일부 필드에는 다음과 같은 특정 매개 변수가 포함되어 있습니다.

Sr. 아니. 매개 변수 및 설명
1

date and datetime

이 필드는 validate.minvalidate.max 최소 및 최대 값을 설정합니다.

2

spacer

그것은 사용합니다 underline 추가하기 <hr> 태그, 다음을 사용하여 텍스트 값 추가 text 및 용도 title <h3> 태그로.

select

그것은 사용합니다 multiple 매개 변수를 사용하여 여러 값을 추가합니다.

4

select and checkboxes

그것은 사용합니다 options 필드를 사용하여 사용 가능한 옵션을 설정합니다.

5

display

그것은 사용합니다 content내용을 표시하는 매개 변수. 그것은markdown 내용을 표시하려면 true로 설정합니다.

6

captcha

그것은 사용합니다 recatpcha_site_keyrecaptcha_not_validated 매개 변수.

Captcha에 대한 참고 사항

필드 아래에 보안 문자 정보에 대한 코드가 있습니다. g-recaptcha-response 아래와 같이-

- name: g-recaptcha-response
   label: Captcha
   type: captcha
   recatpcha_site_key: 6LelOg4TAAAAALAt1CjjjVMxFLKY8rrnednYVbr8
   recaptcha_not_validated: 'Captcha not valid!'
   validate:
		required: true

reCaptcha는 스팸 및 남용으로부터 웹 사이트를 보호하는 데 사용됩니다. 그것은recatpcha_site_key옵션을 선택하고 사이트에 위젯을 표시합니다. reCaptcha를 사용하려면 reCaptcha 문서를 참조하십시오 . reCaptcha가 올바르지 않으면 다음을 사용하여 메시지를 표시합니다.recaptcha_not_validated 선택권.

양식 작업

이메일

아래에서 특정 옵션으로 이메일을 보낼 수 있습니다. process 아래 표시된 필드-

- email:
	from: "{{ config.plugins.email.from }}"
	to: "{{ config.plugins.email.to }}"
	subject: "Contact by {{ form.value.name|e }}"
	body: "{% include 'forms/data.html.twig' %}"

두 개의 필드를 포함하는 이메일 옵션을 사용합니다. 그만큼from 필드는 이메일 주소의 발신자를 지정하고 to필드는 이메일 플러그인 구성을 사용하여 이메일 주소의 수신자를 지정합니다. 이메일 필드는 또한subject 제목이 [담당자] [입력 한 이름]으로 입력 한 이메일로 이메일을 보내고 이메일 본문은 forms/data.html.twig 테마의 파일.

다른 페이지로 이동

다음을 사용하여 다른 페이지로 리디렉션 할 수 있습니다. messagedisplay 아래에 정의 된 옵션 process 들.

process:
   - message: Thank you for getting in touch!
   - display: thankyou

그만큼 message옵션은 사용자가 제출 버튼을 클릭 할 때 표시되어야하는 메시지를 설정합니다. 사용자가 양식을 제출하면 다른 페이지로 리디렉션되어야합니다. 아래에 하나의 하위 페이지를 만듭니다.thankyou 하위 폴더 form.md파일이 저장됩니다. 양식을 제출하면 페이지에 리디렉션되고 위의 메시지가 표시됩니다.

라는 서브 페이지 thankyou/formdata.md 다음과 같은 내용이 있습니다.

---
title: Email sent
cache_enable: false
process:
   twig: true
---

## Your email has been sent!

양식을 제출하면 플러그인이 사용자에게 이메일을 보내고 데이터는 data/folder.

저장

아래에 저장되는 파일에 데이터를 저장하는 데 사용됩니다. user/data 폴더.

예를 들어-

process:
   - save:
      fileprefix: contact-
      dateformat: Ymd-His-u
      extension: txt
      body: "{% include 'forms/data.txt.twig' %}"

데이터는 확장자가 txt 인 텍스트 형식으로 저장됩니다. 시체는templates/forms/data.html.twig 테마의 파일.

다음 화면은 간단한 형태를 보여줍니다-