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 | 유효성 검사가 포함 된 이메일 필드입니다. |
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.min 과 validate.max 최소 및 최대 값을 설정합니다. |
2 | spacer 그것은 사용합니다 underline 추가하기 <hr> 태그, 다음을 사용하여 텍스트 값 추가 text 및 용도 title <h3> 태그로. |
삼 | select 그것은 사용합니다 multiple 매개 변수를 사용하여 여러 값을 추가합니다. |
4 | select and checkboxes 그것은 사용합니다 options 필드를 사용하여 사용 가능한 옵션을 설정합니다. |
5 | display 그것은 사용합니다 content내용을 표시하는 매개 변수. 그것은markdown 내용을 표시하려면 true로 설정합니다. |
6 | captcha 그것은 사용합니다 recatpcha_site_key 과 recaptcha_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 테마의 파일.
다른 페이지로 이동
다음을 사용하여 다른 페이지로 리디렉션 할 수 있습니다. message 과 display 아래에 정의 된 옵션 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 테마의 파일.
다음 화면은 간단한 형태를 보여줍니다-