기본 콘텐츠로 건너뛰기

Javascript로 특정 Element 안의 요소들을 wrapping 하기(Codeigniter)

Javascript로 특정 Element 안의 요소들을 wrapping 하기(Codeigniter)

방금 개발을 하던 중에 Codeigniter의 pagination을 사용하게 됐는데 create_links() 함수를 통해서 출력된 paging 결과에

부트스트랩의 pagination 클래스를 입히고 싶었다.

그래서 어떻게 할까 고민을 하다가 pagination으로 출력될 태그로 예상되는 것들을 추려서

자바스크립트로 화면이 로드될 경우에 해당 paging 영역에 있는 태그 들을 부트스트랩에 포맷에 맞는 형태로

태그를 교체하고 하이퍼링크 주소와 textContent를 대입하는 방식으로 해결했다.

var paging = document.getElementById('paging'); // 페이징 내용이 나올 article 태그의 id

var ul = document.createElement('ul'); // 부트 스트랩을 사용하기 위한 상위 ul 태그

ul.className = 'pagination'; // 부트 스트랩을 적용하기 위해서 클래스 이름을 변경한다.

// for문을 통해서 paging 아래에 미리 생성된 태그들의 개수만큼 루프를 돌게되는데 for(i = 0; i < paging.childElementCount; i++) { // 대문자의 결과가 나오더라 그래서 lowerCase로 고정해준다.

var tagName = paging.children[i].tagName.toLowerCase();

// 기본적으로 현재 링크인 경우에는 strong 태그가 나옴

if(tagName == 'strong') {

var li = document.createElement('li');

var a = document.createElement('a');

// 부트스트랩 적용을 위해서 생성한 태그에 이전 태그의 내용을 대입해준다.

a.textContent = paging.children[i].textContent;

li.innerHTML = a.outerHTML;

}

else if(tagName == 'a') {

var li = document.createElement('li');

var a = document.createElement('a');

a.textContent = paging.children[i].textContent;

a.href = paging.children[i].href;

li.innerHTML = a.outerHTML;

} // 이렇게 적용된 태그들을 ul 태그 하위 태그로 넣어준다.

ul.innerHTML += li.outerHTML;

}

// 최종적으로 paging 태그 안에 집어 넣으면 부트 스트랩의 css가 적용된다.

paging.innerHTML = ul.outerHTML;

from http://braintoast.tistory.com/16 by ccl(A) rewrite - 2020-03-06 20:55:03

댓글

이 블로그의 인기 게시물

[PHP] 코드이그니터 - 파일업로드 구현

[PHP] 코드이그니터 - 파일업로드 구현 파일 업로드 이번에 PHP 프레임워크인 코드 이그니터(Codeigniter)를 사용하여 홈페이지를 만드는데 사용한 이미지 업로드용 코드 입니다. upload 라이브러리를 사용하고 app~ 와 같은 위치에 upload 폴더를 만드고 다음 코드를 사용한다음 ajax 로 호출하여 파일을 업로드 합니다. function index() { // Upload 설정 $config['upload_path'] = './upload/'; $config[\'allowed_types\'] = 'gif|jpg|png'; $config['max_size'] = 100; // 100k $config['max_width'] = 1024; $config['max_height'] = 768; $this->load->library('upload', $config); $data = array(); if (! $this->upload->do_upload("service_image")) { $error = array('error' => $this->upload->display_errors()); } else { //$data = array('upload_data' => $this->upload->data()); $this->output->set_output("./upload/".$this->upload->data('file_name')); } } jquery 를 이용한 파일 업로드 호출 코드 function upload() { var datas, xhr; datas = new FormData(); datas.append( 'service_image', $( ...

2017년 1월 스타트업에서 구인할때 주로 원하는 개발 기술

2017년 1월 스타트업에서 구인할때 주로 원하는 개발 기술 php mysql linux android git kotlin gcm/fcm python mssql mongodb amazon aws ios objective-c swift github python c++ django python postgresql amazon aws html5/css3/javascript android java mysql python c++ c# java aws cloud-server dbms node.js postgresql redis nginx react.js hapi.js amazon aws restful-api angularJS jQuery html5/css3/javascript android firebase custom ui component restful-api asp.net c# html css javascript bootstrap angularjs node.js php mongodb redis 프론트엔드 주요 기술 javascript jquery ajax angularjs wbesocket html5/css3/javascript android ios java xcode node.js coffeescript mysql amazon ec2 amazon es3 android ios node.js php python java ios php mysql apache python android redis node.js jquery msa node.js java restful-api linux nosql golang redis nginx ...

이클립스 코드이그나이터 연동 ( eclipse codeigniter )

이클립스 코드이그나이터 연동 ( eclipse codeigniter ) https://ellislab.com/codeigniter/user-guide/installation/downloads.html 위의 사이트에서 코드이그나이터를 다운 받는다. 다운받은 압축 파일을 풀어 준다. 이클립스에서 php 프로젝트를 생성한 공간에 코드이그나이터 압축파일을 복사 붙여넣기 해준다. 위와 같은 화면이 나오면 정상적으로 연동이 된 것 입니다. from http://nahosung.tistory.com/22 by ccl(A) rewrite - 2020-03-06 16:20:55