[HTML5] <form> 태그 1

2020. 7. 6. 16:21 Web Programing/HTML5

<form> 태그 1


1. 텍스트 입력


(1) 텍스트 필드

사용자로부터 텍스트 입력 받는다. 한줄 정도의 단문에 적당하고 긴 줄의 텍스트는 <textarea> 를 이용한다. 


1) 문법

<input type="text" name="값의 이름" value="값" disabled="disabled" readonly="readonly" />


- type : text를 사용해야 텍스트 필드가 된다. 

- name : 입력한 데이터의 이름

- value : 데이터의 값. 입력한 데이터의 기본 값으로 이 값이 기본적으로 텍스트 필드에 표시된다. 

- disabled : 값으로 disabled을 지정하면 텍스트 필드가 불능 상태가 된다. 서버로 전송해도 이 속성이 설정된 컨트롤의 데이터는 서버로 전송되지 않는다. 

- readonly : 값으로 readonly를 지정하면 텍스트 필드에 값이 입력되지 않는다. 서버로는 데이터가 전송된다. 


2) 예제

example1.html

<!DOCTYPE html>

<html>

    <head>

        <title>생활코딩</title>

        <meta http-equiv="Content-Type" content="text/html;charset=utf-8" >

    </head>

    <body>

        <form action="url" method="GET">

            닉네임 :

            <input type="text" name="nickname" />

            <br />

            <input type="submit" />

        </form>

    </body>

</html>


(2) 비밀번호

보안이 중시되는 데이터의 입력을 받는다.  


1) 예제 

example2.html

<!DOCTYPE html>

<html>

    <head>

        <title>생활코딩</title>

        <meta http-equiv="Content-Type" content="text/html;charset=utf-8" >

    </head>

    <body>

        <form action="url" method="GET">

            비밀번호 :

            <input type="password" name="password" />

            <br />

            <input type="submit" />

        </form>

    </body>

</html>


(3) hidden data

화면상에 표시되지 않는 컨트롤을 생성한다. 서버로 전달할 데이터이지만 사용자에게는 노출될 필요가 없는 데이터인 경우 사용한다. 

사용자가 지정하지 않은 정보의 데이터를 전송하기 위함.


1)  예제

example3.html

<html>

    <head>

        <title>생활코딩</title>

        <meta http-equiv="Content-Type" content="text/html;charset=utf-8" >

    </head>

    <body>

        <form action="url" method="GET">

            이름 :

            <input type="text" name="name" />

            <input type="hidden" name="language" />

            <br />

            <input type="submit" />

        </form>

    </body>

</html>


(4) textarea

여러줄의 텍스트 입력 할 때 사용한다. (text: 한 줄)


1) 문법

<textarea name="값의 이름" rows="행의 수" cols="열의 수" disabled="disabled" readonly="readonly">값</textarea>


rows : 입력한 행위 수 만큼 높이가 정해진다. ex.) 10행

cols : 입력한 열의 수 만큼 폭이 정해진다. ex.) 한 줄에 10글자


2) 예제

example4.html 

<!DOCTYPE html>

<html>

    <head>

        <title>생활코딩</title>

        <meta http-equiv="Content-Type" content="text/html;charset=utf-8" >

    </head>

    <body>

        <form action="url" method="GET">

            내용 : <br />

            <textarea rows="5" cols="20"></textarea> <br />

            <input type="submit" />

        </form>​

    </body>

</html>


2. 선택

(1)  라디오 버튼 

여러개의 항목 중에서 하나만을 선택 할 수 있도록 제한하는 컨트롤


1) 문법

<input type="radio" name="값의 이름" value="값" checked="checked">


- name이라는 속성의 값은 같은 값을 사용하고 있어야 한다.

- value라는 속성의 값은 다른 값을 사용하고 있어야 한다.


2) 예제

example1.html

<!DOCTYPE html>

<html>

        <head>

                <meta http-equiv="Content-Type" content="text/html;charset=utf-8" >

        </head>

        <body>

                <form action="example_receive_single.php" method="POST">

                    관심사 : <br />

                    <input type="radio" name="interest" value="programming" checked="checked" /> 프로그래밍<br />

                    <input type="radio" name="interest" value="design" /> 디자인<br />

                    <input type="radio" name="interest" value="planning" /> 기획<br />

                    <input type="submit" />

                </form>

        </body>

</html>


example_receive_single.php - 사용자가 전송한 데이터를 서버 쪽에서 처리한다. 

<html>

        <body>

                당신의 관심사는? <?=$_POST['interest']?>

        </body>

</html>


(2) 콤보박스

여러개의 항목 중에서 원하는 것을 하나만 선택하는 컨트롤로 흔히 콤보박스라고 부른다. --> 공간의 효율성 높인다.


1) 문법

<select name="값의 이름" multiple="multiple">

   <option value="선택될 경우 name의 값이 됨" selected="selected">값에 대한 표시값</option>

   ...option 반복

</select>


- multiple : 이 속성의 값을 mulitple로 지정하면 여러개의 항목을 선택할 수 있는 컨트롤이 된다. --> 복수 선택 방법(ctrl+항목지정)


2) 예제

example2.html 

<!DOCTYPE html>

<html>

        <head>

                <meta http-equiv="Content-Type" content="text/html;charset=utf-8" >

        </head>

        <body>

                <form action="example_receive_single.php" method="POST">

                        관심사 : <br />

                        <select name="interest">

                                <option value="programming">프로그래밍</option>

                                <option value="design" selected="selected">디자인</option>

                                <option value="planning">기획</option>

                        </select>

                        <input type="submit" />

                </form>

        </body>

</html>


(3) 체크 박스

여러개의 항목 중에서 원하는 것을 복수로 선택할 수 있게 하는 컨트롤로 체크박스라고 부른다.


1) 문법

<input type="checkbox" name="값의 이름" value="값" />


- checkbox는 여러개의 값을 같은 이름으로 전송해야 하기 때문에 연관된 항목들의 name 값을 같은 이름으로 지정한다. 

- name의 이름 끝에 '[]'를 붙이면 서버 쪽에서 실행되는 언어가 이 값을 배열로 인지한다. 


2) 예제

example3.html

<!DOCTYPE html>

<html>

        <head>

                <meta http-equiv="Content-Type" content="text/html;charset=utf-8" >

        </head>

        <body>

                <form action="example_receive_multi.php" method="POST">

                    관심사 : <br />

                    <input type="checkbox" name="interest[]" value="programming" /> 프로그래밍<br />

                    <input type="checkbox" name="interest[]" value="design" /> 디자인<br />

                    <input type="checkbox" name="interest[]" value="planning" checked="checked" /> 기획<br />

                    <input type="submit" />

                </form>

        </body>

</html>​


example_receive_multi.php 

<html>

    <body>

        당신의 관심사는? <br />

        <ul>

            <?php

            foreach($_POST['interest'] as $entry){

                echo "<li>$entry</li>";

            }

            ?>

        </ul>

    </body>

</html>



출처: https://devbox.tistory.com/entry/HTML5-form-태그?category=574553 [장인개발자를 꿈꾸는 :: 기록하는 공간]

'Web Programing > HTML5' 카테고리의 다른 글

[HTML5] <a> 태그  (0) 2020.07.06
[HTML5] <input> 태그  (0) 2020.07.06
[HTML5] <form> 태그_GET과 POST  (0) 2020.07.06
[HTML5] <form> 태그 2  (0) 2020.07.06
[HTML5] 아이프레임과 프레임  (0) 2020.07.06
[HTML5] <meta> 태그  (0) 2020.07.06
[HTML5] 이스케이핑  (0) 2020.07.06
[HTML5] URL  (0) 2020.07.06