post 생성자 함수, 프로토타입 기반 상속

2020. 9. 15. 08:27웹 프로그래밍/JavaScript

PHP

DB에 따옴표( ' 또는 " ) 입력시 치환

$value = "들어갈 '값' 입력";
$value = addslashes($value);

페이지

$query = "SELECT count(1) AS total FROM post_requester WHERE status = 'O' ";
$result = mysql_query($query);
$total = mysql_fetch_assoc($result);
$limit2 = 15;
$total = ceil($total['total']/$limit2);
$_REQUEST['page'] = $_GET['page'] ? $_GET['page'] : 1;


/* 1~10, 11~20, 21~30 페이지 만들기 */
$page_list_start = ceil($_REQUEST['page']*0.1)*10 - 9;
if($page_list_start > $total){
$page_list_start = $total;
}
if($page_list_start < 1){
$page_list_start = 1;
}
$page_list_end =ceil($_REQUEST['page']*0.1)*10;
if($page_list_end > $total){
$page_list_end = $total;
}
if($page_list_end < 1){
$page_list_end = 1;
}

$limit1 = $_GET['page'] ? $_GET['page']*$limit2-$limit2 : 0;

<div class="page">
<?
$left = ceil($_REQUEST['page']*0.1)*10 -19;
if($left < 1){
$left = 1;
}
echo '<a href=\'?bid='.$_REQUEST[bid].'&search_radio='.$_REQUEST['search_radio'].'&category='.$_REQUEST['category'].'&search_input='.$_REQUEST['search_input'].'&page='. $left .'\'><span><</span></a>';
?>
<?
for(;$page_list_start<=$page_list_end ;$page_list_start++){
if($page_list_start == $_REQUEST['page']){
echo '<a href=\'?bid='.$_REQUEST[bid].'&search_radio='.$_REQUEST['search_radio'].'&category='.$_REQUEST['category'].'&search_input='.$_REQUEST['search_input'].'&page='. $page_list_start .'\'><span class=\'selected\'>'.$page_list_start.'</span>';
}
else{
echo '<a href=\'?bid='.$_REQUEST[bid].'&search_radio='.$_REQUEST['search_radio'].'&category='.$_REQUEST['category'].'&search_input='.$_REQUEST['search_input'].'&page='. $page_list_start .'\'><span>'.$page_list_start.'</span></a>';
}
}
?>
<?
$right = ceil($_REQUEST['page']*0.1)*10 +1;
if($right > $total){
$right = $total;
}
echo '<a href=\'?bid='.$_REQUEST[bid].'&search_radio='.$_REQUEST['search_radio'].'&category='.$_REQUEST['category'].'&search_input='.$_REQUEST['search_input'].'&page='. $right .'\'><span>></span></a>';
?>

 

 

JavaScript

AJAX기본 형태

$.ajax({
type: "post",
async : false,
url: "",
data: { 'name1' : value, 'name2' : value2 },
contentType: "application/x-www-form-urlencoded; charset=UTF-8",
success: function(result){ }
});

HTTP -> HTTPS

if(!isset($_SERVER["HTTPS"])) { header('Location: https://'.$_SERVER["HTTP_HOST"].$_SERVER['REQUEST_URI']); }

다음 주소 API


<div id="layer" style="display:none;position:fixed;overflow:hidden;z-index:1;-webkit-overflow-scrolling:touch;">
<img src="//t1.daumcdn.net/localimg/localimages/07/postcode/320/close.png" id="btnCloseLayer" style="cursor:pointer;position:absolute;right:-3px;top:-3px;z-index:1" onclick="closeDaumPostcode()" alt="닫기 버튼">
</div>

<a style="position:relative; margin-right:1px; padding:4px 7px; top:1px; line-height:1.2em;" class="btn_find" href="javascript:DaumPostcode();">주소찾기</a>
<input type="text" name="addr1" id="addr1" size="100" class="input" style="line-height:17px;width:500px;" value="" onClick="DaumPostcode();" readonly="readOnly" placeholder="주소찾기를 이용해서 주소를 입력해주세요" />

<span style="display:inline-block; margin-top:5px;">
<input type="text" name="post" id="post" size="8" class="input" value="" onClick="DaumPostcode();" readonly="readOnly" style="line-height:17px;width:60px;" placeholder="우편번호"/>
<input type="text" name="addr2" id="addr2" size="100" class="input" style="line-height:17px;width:500px;" value="" placeholder="상세주소입력"/>
</span>

<script>
// 우편번호 찾기 화면을 넣을 element
var element_layer = document.getElementById('layer');

function closeDaumPostcode() {
// iframe을 넣은 element를 안보이게 한다.
element_layer.style.display = 'none';
}

function DaumPostcode() {
new daum.Postcode({
oncomplete: function(data) {
// 검색결과 항목을 클릭했을때 실행할 코드를 작성하는 부분.

// 각 주소의 노출 규칙에 따라 주소를 조합한다.
// 내려오는 변수가 값이 없는 경우엔 공백('')값을 가지므로, 이를 참고하여 분기 한다.
var fullAddr = data.address; // 최종 주소 변수
var extraAddr = ''; // 조합형 주소 변수

// 기본 주소가 도로명 타입일때 조합한다.
if(data.addressType === 'R'){
//법정동명이 있을 경우 추가한다.
if(data.bname !== ''){
extraAddr += data.bname;
}
// 건물명이 있을 경우 추가한다.
if(data.buildingName !== ''){
extraAddr += (extraAddr !== '' ? ', ' + data.buildingName : data.buildingName);
}
// 조합형주소의 유무에 따라 양쪽에 괄호를 추가하여 최종 주소를 만든다.
fullAddr += (extraAddr !== '' ? ' ('+ extraAddr +')' : '');
}

// 우편번호와 주소 정보를 해당 필드에 넣는다.
document.getElementById('post').value = data.zonecode; //5자리 새우편번호 사용
document.getElementById('addr1').value = fullAddr;


// 커서를 상세주소 필드로 이동한다.\
document.getElementById('addr2').focus();

// iframe을 넣은 element를 안보이게 한다.
// (autoClose:false 기능을 이용한다면, 아래 코드를 제거해야 화면에서 사라지지 않는다.)
element_layer.style.display = 'none';
},
width : '100%',
height : '100%',
maxSuggestItems : 5
}).embed(element_layer);

// iframe을 넣은 element를 보이게 한다.
element_layer.style.display = 'block';

// iframe을 넣은 element의 위치를 화면의 가운데로 이동시킨다.
initLayerPosition();
}

function DaumPostcode_h() {
new daum.Postcode({
oncomplete: function(data) {
// 검색결과 항목을 클릭했을때 실행할 코드를 작성하는 부분.

// 각 주소의 노출 규칙에 따라 주소를 조합한다.
// 내려오는 변수가 값이 없는 경우엔 공백('')값을 가지므로, 이를 참고하여 분기 한다.
var fullAddr = data.address; // 최종 주소 변수
var extraAddr = ''; // 조합형 주소 변수

// 기본 주소가 도로명 타입일때 조합한다.
if(data.addressType === 'R'){
//법정동명이 있을 경우 추가한다.
if(data.bname !== ''){
extraAddr += data.bname;
}
// 건물명이 있을 경우 추가한다.
if(data.buildingName !== ''){
extraAddr += (extraAddr !== '' ? ', ' + data.buildingName : data.buildingName);
}
// 조합형주소의 유무에 따라 양쪽에 괄호를 추가하여 최종 주소를 만든다.
fullAddr += (extraAddr !== '' ? ' ('+ extraAddr +')' : '');
}

// 우편번호와 주소 정보를 해당 필드에 넣는다.
document.getElementById('post_h').value = data.zonecode; //5자리 새우편번호 사용
document.getElementById('addr_h1').value = fullAddr;

// 커서를 상세주소 필드로 이동한다.\
document.getElementById('addr_h2').focus();

// iframe을 넣은 element를 안보이게 한다.
// (autoClose:false 기능을 이용한다면, 아래 코드를 제거해야 화면에서 사라지지 않는다.)
element_layer.style.display = 'none';
},
width : '100%',
height : '100%',
maxSuggestItems : 5
}).embed(element_layer);

// iframe을 넣은 element를 보이게 한다.
element_layer.style.display = 'block';

// iframe을 넣은 element의 위치를 화면의 가운데로 이동시킨다.
initLayerPosition();
}

// 브라우저의 크기 변경에 따라 레이어를 가운데로 이동시키고자 하실때에는
// resize이벤트나, orientationchange이벤트를 이용하여 값이 변경될때마다 아래 함수를 실행 시켜 주시거나,
// 직접 element_layer의 top,left값을 수정해 주시면 됩니다.
function initLayerPosition(){
var width = 400; //우편번호서비스가 들어갈 element의 width
var height = 500; //우편번호서비스가 들어갈 element의 height
var borderWidth = 2; //샘플에서 사용하는 border의 두께

// 위에서 선언한 값들을 실제 element에 넣는다.
element_layer.style.width = width + 'px';
element_layer.style.height = height + 'px';
element_layer.style.border = borderWidth + 'px solid';
// 실행되는 순간의 화면 너비와 높이 값을 가져와서 중앙에 뜰 수 있도록 위치를 계산한다.
element_layer.style.left = (((window.innerWidth || document.documentElement.clientWidth) - width)/2 - borderWidth) + 'px';
element_layer.style.top = (((window.innerHeight || document.documentElement.clientHeight) - height)/2 - borderWidth) + 'px';
}
</script>

CURL

$data = array('type1'=>'test1', 'type2'=>'test2'); $data = http_build_query($data, '', '&'); $url = "http://test.com/test_wooki.php"; $agent = 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.0.3705; .NET CLR 1.1.4322)'; $ch = curl_init(); //curl 초기화 curl_setopt($ch, CURLOPT_URL, $url); //URL 지정하기 curl_setopt($ch[$i], CURLOPT_USERAGENT, $agent); curl_setopt($ch[$i], CURLOPT_TIMEOUT, 0); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); //요청 결과를 문자열로 반환 curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10); //connection timeout 10초 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); //원격 서버의 인증서가 유효한지 검사 안함 curl_setopt($ch, CURLOPT_POSTFIELDS, $data); //POST data curl_setopt($ch, CURLOPT_POST, true); //true시 post 전송 curl_setopt($ch, CURLOPT_FAILONERROR, 0); // Fail on errors echo $response = curl_exec($ch); curl_close($ch);

CSS

레이블 사용

css -> input:checked + label { background:red; }

html -> <input type="checkbox" id="a"><label for="a">레이블<label>

 

SQL

아직 머 없음

생각나면 올릴게유

728x90

'웹 프로그래밍 > JavaScript' 카테고리의 다른 글

DOM 접근  (0) 2021.08.18
input 접근  (0) 2021.08.18
HTTP -> HTTPS  (0) 2021.07.31
레이어 팝업 기본형태  (0) 2021.07.31
ajax 기본 형태  (0) 2021.03.26