예감

[디자이너의 초보PHP강의 02] 필드 추가시 방법

· 14년 전 · 1377
처음에 저도 이부분이 힘들었습니다. 하지만 원리를 알고 보면 쉽습니다.
필드 추가시에 문제가 되는 부분은 업데이트 할때 에러나는 부분입니다.
 
게시판 리스트와 뷰 부분에서는 따로 손대지 않아도 추가된 필드가 자동으로 불러와집니다.
 
나중에 배우시겠지만 필드를 불러올때 부분적으로 필요한 것만 불러오기도 하고 테이블에 있는 필드를 다 불러오게 하는 방법이 있습니다. 리스트와 뷰 페이지에서는 전체를 다 불러오니...궂이 다른 설정안하셔도 됩니다.
문제는 글쓰기 에서 업데이트 시키는 부분입니다.
 
그누보드의 기본 구조는 공통적으로 사용되는 페이지와 스킨으로 되어 있습니다.
 
게시판을 보면 모두 bbs 폴더에서 write.php 와 board.php로 되어 있습니다.
 
이 파일에는 공통적으로 들어가는 부분들이 적용되어 있고 이 파일에서 스킨파일을 불러와서 스킨마다 다른 설정을 주는 것입니다. 쓰기 페이지는 모두 /bbs/write.php  파일에서 적용된 스킨의 write.skin.php 파일을 불러와서 보여주는 것입니다. 스킨적용은 관리자 > 게시판 관리에서 각각 해줄수 있습니다.
 
일단 필드를 추가하셨다면, 손대야 하는 부분은 딱 한군데 입니다. 스킨의 write_update.skin.php 파일입니다.
기본스킨에서는 저파일이 없을수도 있습니다. 없다면....만들어주시거나 공유하는 스킨들을 보셔서 저파일이 있다면 업로드 해주세요...단, 그 파일에 다른 코드가 있다면 삭제해 주세요...
 
다음에 해줄 부분은 추가된 필드를 글쓸때와 수정할때 적용 되도록 해주는 것입니다.
 
<?
if($w==''){
 $sql = " insert into $write_table
                set wr_bob= '$wr_bob',
                     wr_bob2= '$wr_bob2',
                      wr_bob3= '$wr_bob3'
                     ";
    sql_query($sql);
}else if($w=='u'){
  $sql = " update $write_table
                set wr_bob= '$wr_bob',
                     wr_bob2= '$wr_bob2',
                     wr_bob3= '$wr_bob3' 
              where wr_id = '$wr[wr_id]' ";
    sql_query($sql);
}
?>
 
이렇게 넣어주면 됩니다. 변수 $w가 없으면 디비에 추가해주는 것이고 u 값이면 수정해서 업데이트 해주는 것이지요. 주의 할점은 추가필드의 맨 끝에 , 가 없어야 하는 것입니다. ,가 들어가면 에러납니다.
리스트에서는 $list[$i][wr_bob] 으로 넣어주면 되고 뷰페이지에서는 $view[wr_bob] 라고 넣어주면 됩니다.
 
쉽죠 쉽죠???
 
만일 기본적으로 사용하는 추가필드를 사용한다면...저런 설정 안해도 자동적으로 됩니다. wr_1 ~ wr_10까지 10개를 사용할수 있습니다.
 
단, 정말 주의할점은 필드추가한 것은 모든 게시판에 한것이 아니기 때문에...저 추가된 스킨을 다른 게시판에 적용하면 저 필드가 없다는 메세지가 뜹니다.......
 
꼭 필드를 추가한 게시판에서만 스킨을 사용해야 합니다..
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 1,520
14년 전 조회 4,599
14년 전 조회 1,609
14년 전 조회 3,336
14년 전 조회 1,534
14년 전 조회 1,598
14년 전 조회 1,361
14년 전 조회 1,158
14년 전 조회 2,154
14년 전 조회 1,215
14년 전 조회 1,139
14년 전 조회 1,453
14년 전 조회 1,289
14년 전 조회 1,519
14년 전 조회 1,281
14년 전 조회 2,314
14년 전 조회 2,816
14년 전 조회 1,611
14년 전 조회 1,607
14년 전 조회 1,377
14년 전 조회 3,413
14년 전 조회 1,385
14년 전 조회 1,132
14년 전 조회 1,950
14년 전 조회 2,350
14년 전 조회 1,310
14년 전 조회 1,898
14년 전 조회 1,900
14년 전 조회 1,948
14년 전 조회 2,068
14년 전 조회 1,731
14년 전 조회 9,211
14년 전 조회 1,837
14년 전 조회 2,151
14년 전 조회 1,275
14년 전 조회 1,176
14년 전 조회 1,293
14년 전 조회 1,685
14년 전 조회 2,699
14년 전 조회 1,234
14년 전 조회 2,195
14년 전 조회 2,449
14년 전 조회 1,598
14년 전 조회 1,515
14년 전 조회 1,079
14년 전 조회 1,650
14년 전 조회 1,550
14년 전 조회 1,419
14년 전 조회 1,331
14년 전 조회 1,378
14년 전 조회 1,743
14년 전 조회 2,527
14년 전 조회 1,643
14년 전 조회 1,107
14년 전 조회 1만
14년 전 조회 1,418
14년 전 조회 1,296
14년 전 조회 1,876
14년 전 조회 2,990
14년 전 조회 1,794
14년 전 조회 1,473
14년 전 조회 1,255
14년 전 조회 2,154
14년 전 조회 1,477
14년 전 조회 2,832
14년 전 조회 1,279
14년 전 조회 1,273
14년 전 조회 1,394
14년 전 조회 2,137
14년 전 조회 1,260
14년 전 조회 2,764
14년 전 조회 1,057
14년 전 조회 3,674
14년 전 조회 3,836
14년 전 조회 3,751
14년 전 조회 3,571
14년 전 조회 1,219
14년 전 조회 1,204
14년 전 조회 1,728
14년 전 조회 1,969
14년 전 조회 1,154
14년 전 조회 1,247
14년 전 조회 1,121
14년 전 조회 5,230
14년 전 조회 1,121
14년 전 조회 5,512
14년 전 조회 1,839
14년 전 조회 1,641
14년 전 조회 1,081
14년 전 조회 1,277
14년 전 조회 1,788
14년 전 조회 1,281
14년 전 조회 1,936
14년 전 조회 1,482
14년 전 조회 1,248
14년 전 조회 1,370
14년 전 조회 3,433
14년 전 조회 1,187
14년 전 조회 1,748
14년 전 조회 1,386