Egloos | Log-in
결론에 가보기
결론에 가보기
[공유] jEditable 에서 중복체크하는 방법 구현
jEditable은 jQuery의 플러그인 중에 한개이다.

웹화면에서 특별한 변경없이 특정한 부분(예를 들어서 table 필드중에 한개..)을 
클릭, 더블클릭, ..(이벤트를 정할수 있다) 등을 해서 input 태크(text field, select box..)로 바꾸고 
데이터 1개만을 수정하도록 하는 플러그인이다.

간단히 사용하는 코드를 보자.

<span id="phone" class="dblclick" style="display: inline"><%= @zeous.phone %></span>

html 코드에 class에 특정 키워드(dblclick)을 넣어두고
jQeuery 코드에서는 아래와 같이 저 부분을 잡아낸다

$(function(){
   $('.dblclick').editable("/zeous/update", {
        indicator: "<img src='/images/ajax-loader.gif'>",
        tooltip: "더블클릭 하시면 수정하실 수 있습니다.",
        event: "dblclick",
        type: "text",
        name: "inline_value",
        id: "key",
        width: 150,
        style: "inherit",
        submitdata: {id: "<%= @zeous.pcb_id %>", authenticity_token : "<%= form_authenticity_token %>"}
      });
});

보내는 주소는 /zeous/update 이고 
span 영역을 마우스 왼쪽의 더블클릭 하면 text 로 화면이 바뀌게 되고  submitdata에 text에서 받는것 이외의 데이터를
넘겨줄수 있도록 한다..  (기본적으로 <%= javascript_include_tag "jquery.jeditable" %> 가 있어야 한다)

여기까지가 jEditable의 기본적인 사용방법이다. rails 코드이지만 보기에 큰 무리가 없을것이다.

그런데 jEditable의 기본기능을 사용하였을때 
주민번호와 같은 데이터의 중복체크를 어떻게 해야 할것인가..  사용자에게 alert창으로 보여주고 
변경한 데이터를 원래의 데이터로 돌려놓는 정도만 구현하면 될듯한데..

처음에 고민한 방법은 ajax 호출 자체를 실패로 만드는 것이다. 
500에러나 기타 에러를 발생시키는 방법인데.. 약간 마음에 안든다.. 에러는 아니자나.. 다만 중복일뿐이지..

설마 이런 고민을 나만 하였을까.. 하고 찾아보니..역시나 있다.
댓글의 맨 마지막에 보면 아래와 같은 코드가 있다.. 누가 구현해놓은 것이다. jQuery의 ajax 호출을 이용하여서

$('.edit').editable(function(value, settings){
        $.ajax({ 
                type: 'POST', 
                url: 'save.html', 
                async: false, 
                success: function(data){ 
                        if (/ErRoR:/.test(data)) 
                        { 
                                data = data.replace(/ErRoR:/g, '');
                                alert(data + ' Could not save data.'); 
                                //Back to edit 
                        }
                } 
        }); 
        return(value); 
        }, { 
         indicator : 'Saving...', 
         width     : '170px', 
         cssclass  : 'inlineEdit', 
         cancel    : '
Cancel', 
         submit    : '<br><input type="button" value="Save">',
 });

서버쪽은 이렇게... 
render :text => "ErRoR:"+old_data, :layout => false

서버쪽에서 return 해주는 text 중에 앞부분을 ErRoR로 주고 화면 단에서 그것을 처리 하는 방법이다.
그런데 위의 코드의 단점은.. 화면의 텍스트가 원래의 데이터로 돌아와야 하는데. 새롭게 입력된 데이터로 변경된다는 것이다.

그래서 위의 코드를 참고해서 새롭게 변경한 코드는 
$(".masked_duplicate").editable(function(value, settings) {
        var t_data = value;
        $.ajax({
            type: 'POST',
            url: '/zeous/update',
            async: false,
            data: {inline_value: value, key: $(this).attr("id"), id: "<%= @zeous.pcb_id %>", authenticity_token : "<%= form_authenticity_token %>", is_duplicate: "true"},
            success: function(data)
            {
              if (/ErRoR:/.test(data))
              {
                  data = data.replace(/ErRoR:/g, '');
                  alert(value + ' 는 중복된 데이터 입니다.');
                  t_data = data;
              }
            }
        });
        return(t_data);
      }
ajax 콜하기전에 데이터를 미리 저장해놨다가 실패시에는 과거 데이터로 return 한다. (서버쪽 코드는 동일하다)
so Cool~ 마음에 든다 ^^ 


by 제우스 | 2009/10/19 14:57 | 컴퓨터 | 트랙백 | 덧글(2)
트랙백 주소 : http://zeous.egloos.com/tb/2452741
☞ 내 이글루에 이 글과 관련된 글 쓰기 (트랙백 보내기) [도움말]
Commented by 매드캣 at 2009/10/19 18:14
jQuery의 Ajax호출은 상당히 심플하군요.
제가 쓰는 것은 제 입맛이 맞춘것이라.- _-
Commented by 제우스 at 2009/10/20 12:06
와.. 위에 있는 코드들을 보시고 jQuery의 Ajax가 간단하시다고 하시면 ajax만을 위한 jQuery코드는 더 간단해요..
위에는 이런저런 처리를 위해서 거의 full spec형태를 사용하고 있는 것이기때문에요 ^^

ps. 결혼축하드려요 ^^

:         :

:

비공개 덧글

◀ 이전 페이지 다음 페이지 ▶

카테고리
영화나 책
말말말
컴퓨터
게임이야기
태그
oracle rails 인스턴스변수 리뷰 게임 checkbox 불꽃처럼나비처럼 프로젝트 힘들어 중복체크 wow 성공 ruby 동전 instancevariable jeditable 후회 productowner 근황 애자 C9 스트레스 jquery 영화 selectbox 애자일 duplicate 잡생각 여유 실패
전체보기
최근 등록된 덧글
제가 할수 있는 방법은 울팀장님에..
by 제우스 at 11/20
ProductOwner의 관리라는것이..
by 제우스 at 11/20
Tuna님 반가워요.. ^^ 저번에..
by 제우스 at 11/20
어딘가에서 읽었는데... 애자일..
by Tuna at 11/20
짜증나는 상황이네요. 자기 참여..
by 오리대마왕 at 11/19
아니 그런것 까지는 어떻게 못 하..
by 데지코 at 11/19
^^ 은행마다 해주는곳과 안해..
by 제우스 at 11/12
한번 꽉 채워서 갖다주면 20만원정..
by 홍여사 at 11/12
와.. 위에 있는 코드들을 보시고 j..
by 제우스 at 10/20
jQuery의 Ajax호출은 상당히 ..
by 매드캣 at 10/19
라이프로그
10억
10억

거북이 달린다
거북이 달린다

용의자 X의 헌신
용의자 X의 헌신

마더
마더

터미네이터 : 미래전쟁의 시작
터미네이터 : 미래전쟁의 시작

스타트렉 더 비기닝
스타트렉 더 비기닝

천사와 악마
천사와 악마

노잉
노잉

7급 공무원
7급 공무원

박쥐
박쥐

인사동 스캔들
인사동 스캔들

와이키키 브라더스
와이키키 브라더스

매란방
매란방

건투를 빈다
건투를 빈다

코끼리는 생각하지 마
코끼리는 생각하지 마

배려
배려

벤자민 버튼의 시간은 거꾸로 간다
벤자민 버튼의 시간은 거꾸로 간다

작전
작전

워낭소리
워낭소리

작전명 발키리
작전명 발키리

적벽대전 2 : 최후의 결전
적벽대전 2 : 최후의 결전

트랜스포터 - 라스트미션
트랜스포터 - 라스트미션

디파이언스
디파이언스

사랑하지 않으면 떠나라!
사랑하지 않으면 떠나라!

촐라체
촐라체

쌍화점
쌍화점

황후화
황후화

크리스마스 별장
크리스마스 별장

눈먼 자들의 도시
눈먼 자들의 도시

예스맨
예스맨

순정만화
순정만화

펀치 레이디
펀치 레이디

눈에는 눈 이에는 이
눈에는 눈 이에는 이

전략적 책읽기
전략적 책읽기

돈, 뜨겁게 사랑하고 차갑게 다루어라
돈, 뜨겁게 사랑하고 차갑게 다루어라

좋은 놈, 나쁜 놈, 이상한 놈
좋은 놈, 나쁜 놈, 이상한 놈

다크 나이트
다크 나이트

H2 1
H2 1

그림으로 읽는 생생 심리학
그림으로 읽는 생생 심리학

호모 코레아니쿠스
호모 코레아니쿠스

강철중: 공공의 적 1-1
강철중: 공공의 적 1-1

이채원의 가치투자
이채원의 가치투자

쿵푸 팬더
쿵푸 팬더

카불의 사진사
카불의 사진사

인디아나 존스 4 - 크리스탈 해골의 왕국
인디아나 존스 4 - 크리스탈 해골의 왕국

시골의사의 부자경제학
시골의사의 부자경제학

종자돈 700만 원으로 부동산 투자 200억 만들기
종자돈 700만 원으로 부동산 투자 200억 만들기

우리동네
우리동네

디지로그 digilog
디지로그 digilog

대하소설 주역 4
대하소설 주역 4

읽지 않은 책에 대해 말하는 법
읽지 않은 책에 대해 말하는 법

Stick 스틱!
Stick 스틱!

색즉시공 시즌 2
색즉시공 시즌 2

바르게 살자
바르게 살자

20대는 통장을, 40대는 인생을 채워라
20대는 통장을, 40대는 인생을 채워라

점퍼
점퍼

생로병사의 비밀
생로병사의 비밀

추격자
추격자

오늘의 거짓말
오늘의 거짓말

주식시장을 이기는 작은책
주식시장을 이기는 작은책

대한민국 진화론
대한민국 진화론

무방비 도시
무방비 도시

피라니아 이야기
피라니아 이야기

우아한 세계
우아한 세계

경제를 읽는 기술
경제를 읽는 기술

실용주의 프로그래머
실용주의 프로그래머

블로그 비즈니스
블로그 비즈니스

어거스트 러쉬
어거스트 러쉬

세븐데이즈
세븐데이즈

뷰티풀 선데이
뷰티풀 선데이

괴물 1
괴물 1

킹덤
킹덤

당신과 일하기 힘들어 죽겠어
당신과 일하기 힘들어 죽겠어

뉴욕의 프로그래머
뉴욕의 프로그래머

나를 바꾸는 데는 단 하루도 걸리지 않는다
나를 바꾸는 데는 단 하루도 걸리지 않는다

벽오 금학도
벽오 금학도

해바라기
해바라기

펀드투자가 미래의 부를 결정한다
펀드투자가 미래의 부를 결정한다

상식이 통하는 웹사이트가 성공한다
상식이 통하는 웹사이트가 성공한다

아버지의 가계부
아버지의 가계부

본 얼티메이텀
본 얼티메이텀

최강 로맨스
최강 로맨스

여자도 여자를 모른다
여자도 여자를 모른다

부동산 10년 대폭락 시나리오
부동산 10년 대폭락 시나리오

아키텍트 이야기
아키텍트 이야기

보물지도
보물지도

오션스 13
오션스 13

게임회사 이야기
게임회사 이야기

바람피기 좋은 날
바람피기 좋은 날

조폭 마누라 3
조폭 마누라 3

삼미 슈퍼스타즈의 마지막 팬클럽
삼미 슈퍼스타즈의 마지막 팬클럽

광기와 우연의 역사
광기와 우연의 역사

런어웨이
런어웨이

회사가 당신에게 알려주지 않는 50가지 비밀
회사가 당신에게 알려주지 않는 50가지 비밀

롱테일 법칙
롱테일 법칙

해리 포터와 불사조 기사단
해리 포터와 불사조 기사단

사소한 것에 목숨 걸지 마라 - 습관 바꾸기 편
사소한 것에 목숨 걸지 마라 - 습관 바꾸기 편

우리가 미처 알지 못한 소프트웨어 공학의 사실과 오해
우리가 미처 알지 못한 소프트웨어 공학의 사실과 오해

트랜스포머
트랜스포머

20대부터 시작하는 스트레스 제로기술
20대부터 시작하는 스트레스 제로기술

미운오리새끼의 출근
미운오리새끼의 출근

캐리비안의 해적 : 세상의 끝에서
캐리비안의 해적 : 세상의 끝에서

미녀는 괴로워
미녀는 괴로워

유태우 교수의 내몸개혁 6개월 프로젝트
유태우 교수의 내몸개혁 6개월 프로젝트

브레이크 업 : 이별후애(愛)
브레이크 업 : 이별후애(愛)

인사이드 맨
인사이드 맨

마키아벨리, 회사에 가다
마키아벨리, 회사에 가다

웹 2.0 경제학
웹 2.0 경제학

한반도
한반도

연애, 그 참을 수 없는...
연애, 그 참을 수 없는...

구미호 가족
구미호 가족

럭키 넘버 슬레븐
럭키 넘버 슬레븐

찰리와 초콜릿 공장
찰리와 초콜릿 공장

아파트
아파트

레전드 오브 조로
레전드 오브 조로

rss

skin by jiinny
X