크리스의 개발일기

[jqgrid] jqgrid 고도화 / jqgrid 효율적으로 선언하기 본문

jQuery

[jqgrid] jqgrid 고도화 / jqgrid 효율적으로 선언하기

ChrisJang 2021. 4. 6. 15:29

 

<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ page import="java.util.Date" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>
<c:import url="/common/leftHeader.do?link=common/leftHeader" />

<style>
</style>

<%-- javascript 는 Header에 작성한다. --%>
<script type="text/javascript">

    //---------------------------------------------------------------------------------------
	//document.ready 위에 이벤트 할당한 후 호출하여 사용하거나  document.ready 안에 할당하세요.
    이벤트 할당 ex) // document.ready 위에 (예:_initEvent) 함수를 작성하여 document.ready 안에서 (예:_initEvent) 함수를 호출하여 사용하는 예시
	var _initEvent = function(){
	
	    $("#aaa").on("click",function(){
		alert(1);
		}

		$("#bbb").on("click",function(){
		var aaa = "sample";
		console.log(aaa);
		}

		$("#searchBtn").on("click", function(){
            var sSdate   = $("#sDate").val();
            var sTeamNm  = $("#teamNm").val();
            var param = {sDate : sSdate, teamNm : sTeamNm};
            fn_search('list','url', param);
        });

		$('#delBtn').on('click', function(e) {
            fn_deleteConfirmMessage('fnDelete');
        });
	}

    //---------------------------------------------------------------------------------------
	// document.ready 안에서 호출하여 사용할 함수를 작성하세요.
	function _sample(){
	    alert(1);
	}

    //---------------------------------------------------------------------------------------
	그리드 초기화 ex) // document.ready 위에 (예:_initGrid) 함수를 작성하여 document.ready 안에서 (예:_initGrid) 함수를 호출하여 사용하세요.
	               // _initGrid 안에 그리드를 다 작성하세요.
				   // 그리드 헤더(colNames)를 배열로 만들어 가독성 좋게 작성하세요.
				   // 그리드 옵션은 필요한것만 사용하세요.
				   // url : index.html 같은 필요 없는 요청은 보내지 마세요.

    var _initGrid = function() {
		
		//상단 그리드 헤더그리기 (colNames)
		var arrHeaderList = [];
        arrHeader.push("state");
        arrHeader.push("AAA");
        arrHeader.push("BBB");

		$("#list").jqGrid({
              datatype    : 'local'
             ,mtype       : "POST"
             ,loadtext    : "로딩중..."
             ,viewrecords : true
             ,colNames    : arrHeaderList
             ,colModel    : [
                             {name:'state',  index:'1',  editable:false, hidden: true}
                            ,{name:'aaa',    index:'2',  editable:false, hidden: true}
                            ,{name:'bbb',    index:'3',  editable:false, width:"10%", align:"center"}
							]
			 ,height      : 100
             ,autowidth   : true
             ,jsonReader  : {root:"row", records:"records", repeatitems:false, id:"id"}
             ,rowNum      : 100
		});
	    //url 없이 사용하려면 각각의 그리드마다 $('#그리드id값').jqGrid('setGridParam', { 'datatype' : 'json' }); 작성하여야 합니다.
		$('#list').jqGrid('setGridParam', { 'datatype' : 'json' });

        //상단 그리드 헤더그리기 (colNames)
		var arrHeaderList2 = [];
        arrHeader.push("state");
        arrHeader.push("CCC");
        arrHeader.push("DDD");

		//그리드 옵션은 필요한것만 사용하세요.
        // url : index.html 같은 필요 없는 요청은 보내지 마세요.
		$("#list2").jqGrid({
           ,datatype    : "local"
           ,loadtext    : "로딩중..."
           ,viewrecords : true
           ,colNames    : arrHeaderList2
           ,colModel    : [{name:'state', index:'1', editable:false, align: 'center', hidden:true}
                          ,{name:'ccc',   index:'2', editable:false, align: 'center', width:"15%"}
                          ,{name:'ddd',   index:'3', editable:false, align: 'left', width:"25%"}
                          ]
           ,height      : 200
           ,autowidth   : true
           ,jsonReader  : {root:"row", records:"records", repeatitems:false, id:"id"}
           ,rowNum      : 100
		});
		//url 없이 사용하려면 각각의 그리드마다 $('#그리드id값').jqGrid('setGridParam', { 'datatype' : 'json' }); 작성하여야 합니다.
	    $('#list2').jqGrid('setGridParam', { 'datatype' : 'json' });
	
	};

    //---------------------------------------------------------------------------------------
	***** DOM이 다 그려진후 document.ready가 실행됨. *****
    $(document).ready(function() {

	ex.날짜 셋팅하기) : fn_date_value("eDate");

	ex.이벤트할당) : _initEvent();

	ex.그리드초기화) : _initGrid();

	ex.화면이 열릴때 바로 조회하고 싶으면 trigger 함수를 사용합니다.) : $("#searchBtn").trigger("click");
	// #searchBtn 이벤트가 발생하여 그리드(id=list)를 조회한다.

	});

HTML 은 Body에 작성합니다.

<div>
    <div style="float:right">
        <button type="button" title="조회" class="btn" id="searchBtn">조회</button>
        <button type="button" title="삭제" class="btn" id="delBtn">삭제</button>
    </div>
	<div class="grid-area" style="width:100%;">
        <table id="list"></table>
    </div>
	<div class="grid-area" style="width:100%;">
        <table id="list2"></table>
    </div>
	<div style="float:left">
        <button type="button" title="조회" class="btn" id="aaa">aaa버튼</button>
        <button type="button" title="삭제" class="btn" id="bbb">bbb버튼</button>
    </div>
</div>

	

 

'jQuery' 카테고리의 다른 글

[jQuery] jqgrid 간단한 사용법  (0) 2020.11.30
[jQuery] selector란 무엇인가? (수정)  (0) 2020.11.08
Comments