웹마스터 팁

php를 이용한다면 XE의 addon, module trigger 기능을 사용하면 되지만


javascript의 경우는 마땅치 않아서 jquery를 사용할 수 있는 사용자에게 유용한 팁이지 않을까해서 올려봅니다.


묻고 답하기에 이와 유사한 질의들이 있고해서 답변겸 올려봅니다.


예제로 닉네임 클릭시 나오는 팝업창을 XE코어 수정없이 변경해 보도록 하겠습니다.



(function($) {


	var displayPopupMenuByCore = window.XE.displayPopupMenu;

	window.XE.displayPopupMenu = function( ret_obj, response_tags, params ) {
		// Log the fact that we are calling our override.
//		console.log( ret_obj );

		// Execute the original method.
//		displayPopupMenuByCore.apply( this, arguments );

		var target_srl = params.target_srl;
		var menu_id = params.menu_id;
		var menus = ret_obj.menus;
		var html = "";


		if(this.loaded_popup_menus[menu_id]) {
			html = this.loaded_popup_menus[menu_id];


		} else {
			if(menus) {
				var item = menus.item;
				if(typeof(item.length)=='undefined' || item.length<1) item = new Array(item);
				if(item.length) {
					for(var i=0;i<item.length;i++) {
						var url = item[i].url;
						var str = item[i].str;
						var icon = item[i].icon;
						var target = item[i].target;


						var styleText = "";
						var click_str = "";
						/* if(icon) styleText = " style=\"background-image:url('"+icon+"')\" "; */
						switch(target) {
							case "popup" :
									click_str = 'onclick="popopen(this.href, \''+target+'\'); return false;"';
								break;
							case "javascript" :
									click_str = 'onclick="'+url+'; return false; "';
									url='#';
								break;
							default :
									click_str = 'target="_self"';
								break;
						}


						html += '<li '+styleText+'><a href="'+url+'" '+click_str+'>'+str+'</a></li> ';
					}
				}
			}
			this.loaded_popup_menus[menu_id] =  html;
		}

		/* 레이어 출력 */
		if(html) {
			var area = $('#popup_menu_area').html('<ul>'+html+'</ul>');
			var areaOffset = {top:params.page_y, left:params.page_x};


			if(area.outerHeight()+areaOffset.top > $(window).height()+$(window).scrollTop())
				areaOffset.top = $(window).height() - area.outerHeight() + $(window).scrollTop();
			if(area.outerWidth()+areaOffset.left > $(window).width()+$(window).scrollLeft())
				areaOffset.left = $(window).width() - area.outerWidth() + $(window).scrollLeft();


			area.css({ top:areaOffset.top, left:areaOffset.left }).show().focus();
		}
	}

}) (jQuery);


위의 코드중에
var displayPopupMenuByCore = window.XE.displayPopupMenu;
기존 XE코어 ./common/js/common.js에 있는 window.XE.displayPopupMenu 원래 함수를 displayPopupMenuByCore 에 저장시키는 것입니다.
이것은 추후 원래함수를 호출할 경우가 있을때 사용하기 위한 것입니다.


그다음에 코어와 똑같은 함수를 만들어서 원하는 기능을 함수내에 넣으시면 됩니다.
window.XE.displayPopupMenu = function( ret_obj, response_tags, params ) {
.
.
내용
.
.
}

예제에 포함된 내용은 단순히 링크 클릭시 target="_blank" 를 target="_self" 로 바꾸어주는 기능 입니다.

사용은 레이아웃 제일 하단에 아래코드를 넣어주면 됩니다.(이유는 코어의 script들이 먼저 로딩된후에 불러와야 하기 때문입니다.)
<load target="./member_control.js" type="body" />


팝업메뉴가 안뜨게 하고 싶다면
window.XE.displayPopupMenu = function( ret_obj, response_tags, params ) {
return;
}

jquery를 공부하시면서 XE코어의 jquery기능을 원하시는 기능으로 코어수정 없이 대체해 보시는것도 좋을것 같습니다. ^^

제목 글쓴이 날짜
lang.xml 키워드 사용체크 프로그램 (리눅스/파이썬) file NURIGO 2014.03.19
모바일 화면 사이즈 관련 팁 젤리빈 2014.03.19
폰갭 이용시 파일 첨부 한번에 올리기 웹빌드 2014.03.20
[Jquery] input box border input pell 2014.03.21
XE코어 수정없이 원하는 기능 넣기 [3] file 마이웹 2014.03.22
사용자에게 파일 내용을 뿌릴땐 fpassthru를 쓰자 [2] DynamicLaser 2014.03.23
로그인 안하면 코멘트 볼 수 없게 스킨 수정하는 법 [3] W.O 2014.03.23
메인 홈페이지와 서브페이지를 하나의 레이아웃으로 투씨 2014.03.24
VB.NET에서 XE로그인 연동하기.[내용추가] [3] AppSeedKorea 2014.03.26
[SocialXE] 1.7.4.x 업데이트 후 SocialXE에서 '잘못된 요청입니다.' 오류가 뜨는 문제 해결하기 [15] file TUW 2014.03.26
여러가지 hover effect 모음 [1] 드래그홈 2014.03.26
여러가지 프로토타이핑 툴 [1] 드래그홈 2014.03.26
모바일EX 사용시, 모바일 레벨아이콘 출력하기. [11] qwms 2014.03.29
index.php에서 Parse Error가 발생한다면 [6] YJSoft 2014.04.01
[javascript]기초강좌 | 01 자바스크립트개념 hiwebs 2014.04.01
[javascript] 기초강좌 | 02 산술, 대입, 증감, 비교연산자 hiwebs 2014.04.01
코어 업데이트 후 회원가입 이름이 숫자(번호)로 뜨는 현상 수정 [1] 자대련 2014.04.01
slidesj 사용시 자동으로 다음 사진 넘길때 웹빌드 2014.04.02
이전/다음 글버튼 출력 애드온의 버튼을 사이트 밖으로 빼봅시다..^^ [5] file 착한악마 2014.04.03
관리자를 제외하고는 타회원의 회원정보 보기를 막는 방법 [1] sejin7940 2014.04.04