다중체크 문자열 치환 질문좀 드리겠습니다 채택완료
작은별님께서 알려주신링크로 원하는걸 결과를 얻었지만 다른부분문제로 문의드립니다
write
write_update_skin
$schedule= "$schedule[0],$schedule[1],$schedule[2],$schedule[3]"; // 옵션1 $sql = "UPDATE ".$write_table." SET schedule=".$schedule." WHERE idx=".$idx; sql_query($sql);
문학 역사를 체크하고 저장하면 디비에 문학,역사 이렇게 들어가는게 아니고 ,문학,역사, 이렇게 체크가 없는거는 ,가 들어가는데 체크한것만 들어가게 하고 싶습니다
그리고 view페이지에서 로 불러오면
문학 역사 이렇게 나오게 되어있는데 마찬가지고 문학,역사 이렇게 보여주고 싶습니다
조금만 도움을 주시면 감사하겠습니다
답변 3개
$schedule= "$schedule[0],$schedule[1],$schedule[2],$schedule[3]"; // 옵션1
$schedule = implode(",", $_POST['schedule']);
답변에 대한 댓글 5개
[code]
$schedule = explode(",", $write['schedule']);
$items = array("수학", "문학", "역사", "영어");
foreach($items as $v) {
$cheked = in_array($v, $schedule) ? " checked" : "";
echo "<input type='checkbox' name='schedule[]' value='".$v."'".$checked." />";
}
[/code]
write_update.skin.php
[code]
$schedule = implode(",", $_POST['schedule']);
[/code]
지금 질문을 남기신 콤마를 없앤다는 것 자체가 앞에 배열마다 인덱스를 넣으신 걸 놓고 보면 말이 안 되는 겁니다. 그리고 배열은 굳이 인덱스를 따로 지정 안 하셔도 됩니다. 자동적으로 0부터 시작입니다.
이렇게 출력이됩니다..잘 가르쳐주시는데 실력이 못따라가서 번거롭게 해드려서 죄송합니다
디비에 값이 콤마 없이 수학,영어 이렇게 들어갔다고 가정을 하면 write.php 페이지에서 in_array로 배열 중에 값이 있는지 체크를 해서 있는 애들만 checked 값을 줘서 체크되게 처리합니다.
$items = array("수학", "문학", "역사", "영어");
print_r($schedule);
이렇게 찍어 보세요. 값이 어떻게 나오는지.
체크를 해보니 Array ( [0] => 문학 [1] => 영어 ) 이렇게 값은 정상적으로 들어가지만 체크박스에 체크가 안되고있습니다.
댓글을 작성하려면 로그인이 필요합니다.
</p>
<p>$str = "";</p>
<p>foreach($schedule as $key => $value) {</p>
<p> if ($value) {</p>
<p> if ($str) $str .= ", ";</p>
<p> $str .= $value;</p>
<p> }</p>
<p>}</p>
<p>$sql = "UPDATE ".$write_table." SET schedule=".$str." WHERE idx=".$idx;
sql_query($sql);</p>
<p>
이렇게 하시면 될겁니다.
답변에 대한 댓글 1개
Array로 나옵니다..
댓글을 작성하려면 로그인이 필요합니다.
답변을 작성하려면 로그인이 필요합니다.
로그인
수학 문학을 체크하면 체크표시가 제대로 나오지만
수학 영어 또는 문학 역사 를 하면 체크표시가 안보입니다