포럼

얼마 전에 방명록 보완하면서 방명록은 한번에 보는 글 수도 많아
문서 하나하나마다 에디터로 불러오면 너무 브라우저 로딩이 심하길래
<textarea>로 댓글입력창을 교체했습니다. 

댓글을 에디터 불러옴 없이 <textarea> 이렇게 한줄로 처리하니 가볍고 좋았는데.. 근데..

글을 쓰고 엔터를 쳐도 글입력시에는 엔터로 줄바꿈이 되지만, 정작 등록된 글은 엔터없이 띄어쓰기만 되네요.

예를 들면, 'aaa (엔터) bbb' 라고 입력하면 입력 후 본문 글에서는 'aaa bbb' 이렇게 보입니다.


----------
해결하려고 다음의 방법을 뒤져봤는데..
1. xpresseditor 의 'html 사용없이 자동줄바꿈' 이란 기능을 보고 나름 js 등 같은 방식(?)으로 구현.
2. 모바일 스킨은 <textarea>로 글 입력하는데 줄바꿈이 되길래 따라해봤더니 -> 모바일스킨 코드를 그대로 일반 스킨 코드로 가져와도 모바일 보기에서는 줄바꿈이 되고, 일반 웹브라우저 보기에서는 줄바꿈이 안되네요.. 아무리 봐도 차이를 모르겠는데 ㅠ.ㅠ
3. 소셜XE -> 아래 난다날아님 답변처럼 n2br php함수(?)  

------------
<우선 1번의 방법으로 해결함>

- 아래 코드는 xpresseditor의 textarea.js 부분에서 가져와 필요한 부분만 수정한 겁니다.
php을 제가 몰라 일단 당장 보이는 에디터를 건드렸는데,
너무 비효율적인 것 같아 다른 분들의 의견을 듣고자 합니다. 
php로 간단히 처리하는 방법이 있다면 알려주심 감사하겠습니다.

ps. 그리고 모바일 스킨에서는 특별한 코드없이 줄바꿈이 되는 데요, 이유를 알 수 있을까요? 이유가 답이겠죠? ^^;;

--------- 이하 수정한 코드 ------------


1. view_document.html 댓글창 부분
<form action="./" method="post" onsubmit="jQuery(this).find('input').each(function(){if(this.title==this.value)this.value='';});return procFilter(this, insert_comment)" editor_sequence="{$oDocument->document_srl}">
<input type="hidden" name="mid" value="{$mid}" />
<input type="hidden" name="document_srl" value="{$oDocument->document_srl}" />
<input type="hidden" name="comment_srl" value="" />
<textarea  id="editor_{$oDocument->document_srl}" name="content"></textarea>
<input type="submit" value="{$lang->cmd_registration}" />
</div>
</form>
<script type="text/javascript">
editorStartTextarea({$oDocument->document_srl}, "content", "comment_srl");
</script>



2. board.js 에 다음 추가


var editorRelKeys = new Array();
function editorStartTextarea(editor_sequence, content_key, primary_key) {
    var obj = xGetElementById('editor_'+editor_sequence);
    obj.form.setAttribute('editor_sequence', editor_sequence);
    editorRelKeys[editor_sequence] = new Array();
    editorRelKeys[editor_sequence]["primary"] = obj.form[primary_key];
    editorRelKeys[editor_sequence]["content"] = obj.form[content_key];
    editorRelKeys[editor_sequence]["func"] = editorGetContentTextarea;
    var content = obj.form[content_key].value;
content = content.replace(/<br([^>]*)>/ig,"\n");
content = content.replace(/&lt;/g, "<");
content = content.replace(/&gt;/g, ">");
content = content.replace(/&quot;/g, '"');
content = content.replace(/&amp;/g, "&");
    obj.value = content;
}
function editorGetContentTextarea(editor_sequence) {
    var obj = xGetElementById('editor_'+editor_sequence);
    var content = obj.value.trim();
content = content.replace(/&/g, "&amp;");
content = content.replace(/</g, "&lt;");
content = content.replace(/>/g, "&gt;");
content = content.replace(/\"/g, "&quot;");
content = content.replace(/(\r\n|\n)/g, "<br />");
    return content;
}

-----------

글쓴이 제목 최종 글
Treasurej 앱에서 글쓰기 됐으면 좋겠네요.^^  
씨지 모듈확장시 queries xml 파일도 확장(override)시킬 수 있는건가요? [2] 2011.04.22 by 씨지
에혀라X 1.4.5 업뎃이후 가상호스트 접속문제 [1] 2011.04.20 by senate
오왕록 버전 업데이트하고난 후 페이지가 안열려요.... [2] 2011.04.20 by 어라하여
ksdwm72 기본이자 핵심 에러에 대한 긴급 패치 및 공지에 대해 [6] 2011.04.19 by Garon
김 무건 이제 iePngFix 는 지원 안하나요? [2] 2011.04.18 by criuce
정찬명 XE개발팀이 묻고 답하기 게시판에 답변을 달지 못하는 이유. [8] 2011.04.16 by 디제이쿠
씨지 검색엔진 친화적인 Sitemap 프로토콜 모듈 [1] 2011.04.15 by redred
참목자 제로보드xe 앨범 에러 관련 문의드려요. 꼭 빠른 답변 부탁드려요..  
라온넷닷컴 slow query 발생 [1] 2011.04.14 by sol
Treasurej XE에서 자바스크립트문? [4] 2011.04.14 by sol
친절뺀질이 레이아웃 변경에 대해 문의드립니다. [6] 2011.04.14 by 몽이130
hika1 댓글창을 <textarea>로 만들고<br> 자동입력 [4] 2011.04.13 by hika1
행복한고니 [설문조사] 운영중인 사이트의 게시판 갯수 최고는? [21] 2020.03.14 by redred
sangjaezzi XE 스페인어로 번역 지원합니다. [2] 2011.04.11 by misol
푸름빠 모바일 게시판 스킨에서 파일업로드 기능에 대해 [1] 2011.04.11 by DongJaiㅡ★
글문 1.4.5 버젼 업데이트 될 적에 변경 사안 중에서 변경되지 않고 있는 것이 있네요.  
SMaker XE의 스킨에 대한 문제점에 대해 토론해봅시다. [2] 2011.04.09 by SMaker
정찬명 공모전 소개 페이지가 열렸습니다. ^^ [6] 2011.04.09 by neostream
misol 약간의 투덜투덜.. http://xe.xpressengine.net/19678731 관련