분류 전체보기 233

[agGrid] row 선택 이벤트

onSelectionChanged와 onRowSelected는 모두 ag-Grid에서 row selection 관련 이벤트를 처리하기 위한 콜백 함수입니다. 두 함수는 파라미터가 다르므로 필요한 데이터에 따라 선택하여 사용하면 될 것 같습니다. 1. onSelectionChanged api.getSelectedNodes() 및 api.getSelectedRows() 메서드를 사용하여 선택한 노드/행 데이터의 새 목록을 가져옵니다. api.getSelectedNodes() 메서드는 선택된 모든 row의 Node 객체를 반환합니다. api.getSelectedRows() 메서드는 선택된 모든 row의 데이터 객체를 반환합니다. // gridOptions 객체 설정 var gridOptions = { onSe..

gridLib/agGrid 2023.05.03

[agGrid] 동적 row select (getSelectedNodes, getSelectedRows, setSelected, selectNode)

ag-Grid에서 rowSelection 속성을 multiple 또는 single로 설정하여 다중 또는 단일 선택을 활성화할 수 있습니다. 팝업창에 rowSelection속성이 multiple인 그리드가 있고, 팝업을 닫을 때 선택했던 row를 저장해뒀다가 다시 팝업을 열 때 저장된 데이터를 그리드에서 선택되도록 하려고 합니다. ag-Grid에서 row를 동적으로 선택하기 위해서는 다음과 같은 두 가지 방법을 사용할 수 있습니다. 1. selectNode api.selectNode(node, tryMulti): 지정된 노드를 선택하고 선택한 상태로 변경합니다. node: 선택할 노드입니다. tryMulti (선택적): true로 설정하면 노드를 다중 선택할 수 있습니다. 예를 들어, 특정 인덱스의 노드를..

gridLib/agGrid 2023.05.02

[agGrid] cellEditor 옵션 (select)

agCellEditor 기본 input default 값으로 editable을 true로 주고 cellEditor을 설정하지 않았을 때 나타난다. let colDef = [ { field: 'columnID', headerName: 'columnID', editable: true, cellEditor: 'agCellEditor', cellEditorParams: {} }, { field: 'type', headerName: 'type' } ]; agSelectCellEditor 무료 버전인 ag-grid-community에서 사용할 수 있는 select 옵션입니다. let colDef = [ { field: 'columnID', headerName: 'columnID', editable: true, ce..

gridLib/agGrid 2023.04.28

객체 분해 할당(Object Destructuring Assignment)

객체 분해 할당(Object Destructuring Assignment)은 ES6에서 추가된 기능으로, 객체의 속성들을 변수로 분해해서 할당하는 방법입니다. 객체 분해 할당은 객체의 속성에 접근해서 변수로 할당하는 것과 유사합니다. 다만, 객체 분해 할당을 사용하면 코드가 간결해지고 가독성이 좋아지는 장점이 있습니다. 객체 분해 할당은 중괄호({})를 사용하여 객체를 선언하고, 변수 이름을 할당할 속성 이름으로 지정합니다. 이 때, 할당할 변수 이름은 객체의 속성 이름과 일치해야 합니다. 예를 들어, 다음과 같은 객체가 있다고 가정해보겠습니다. const person = { name: 'John', age: 30, city: 'New York' }; 이 객체를 분해해서 name, age, city 변수..

Frontend/javaScript 2023.04.28

[javaScript] map() 함수 (number, string, object arr 예시)

map() map() 함수는 JavaScript 배열에서 사용할 수 있는 내장 함수 중 하나로, 배열의 모든 요소를 변환하고 새로운 배열을 생성합니다. map() 함수는 각 배열 요소에 대해 콜백 함수를 호출하고, 콜백 함수가 반환한 값을 새로운 배열에 추가합니다. 이 때 원래 배열은 변경되지 않고, 새로운 배열만 생성됩니다. arr.map(callback(element, index, array), thisArg) callback: 각 배열 요소에 대해 호출할 함수로, 콜백 함수는 다음과 같은 매개 변수를 받습니다. element: 현재 처리 중인 배열 요소 index: 현재 처리 중인 요소의 인덱스 array: map() 함수가 호출된 배열 thisArg (선택 사항): 콜백 함수에서 this 키워드가..

Frontend/javaScript 2023.04.28

eslint-disable not working

ESLint ESLint는 자바스크립트 코드에서 문제를 검사하고 일관성 있는 코드 스타일을 유지할 수 있도록 도와주는 정적 코드 분석 도구입니다. ESLint는 사용자가 직접 규칙을 만들거나 다른 사용자가 만든 규칙을 사용할 수 있는데 이 때문에 코드의 문법에 문제가 없어도 규칙을 어기면 에러가 뜹니다. 미리 작성된 template기반으로 동적으로 Vue 코드를 생성해주는 프로그램을 개발중에 띄어쓰기, 줄바꿈 같은 규칙까지 지키면서 만들 수가 없어서 eslint-disable을 사용했습니다. Disable vscode의 Quick Fix에서는 두가지 disable 옵션이 있습니다. - Disable prettier/prettier for this line 에러 나는 코드 위에 해당 구문을 추가하는데 이는..

Frontend/javaScript 2023.04.27

[JAVA] 자바 외부 파일/ 외부 프로그램/ 명령어 실행 (exec)

exec() exec() 메소드는 Runtime 클래스의 getRuntime() 메소드를 사용하여 Runtime 객체를 생성한 다음, Runtime 객체의 exec() 메소드를 호출하여 외부 프로그램을 실행합니다. exec() 메소드는 실행할 외부 프로그램의 이름, 매개변수, 작업 디렉토리 등을 인자로 전달할 수 있습니다. public Process exec(String command, String[] envp, File dir) 매개변수 command: 지정된 시스템 명령. envp: 문자열 배열, 각 요소에 name=value 형식의 환경 변수 설정이 있거나 하위 프로세스가 현재 프로세스의 환경을 상속해야 하는 경우 null입니다. dir: 하위 프로세스의 작업 디렉토리, 하위 프로세스가 현재 프로세..

Backend/JAVA 2023.04.26

[javaScript] 파일 업로드, 다운로드 (파일 깨짐 해결, readAsArrayBuffer, btoa, _arrayBufferToBase64)

1. 파일 손상문제 발생 자바스크립트 단에서 파일을 DB에 업로드, 다운로드를 진행하다가 파일이 깨지는 문제가 발생했습니다. 아래는 문제가 발생했을 당시 코드입니다. var reader = new FileReader(); const file = document.getElementById("fileInput").files[0]; const fileName = file.name; const fileSize = file.size; const fileType = file.type; let fileBlob = ""; reader.readAsArrayBuffer(file); reader.onload = function (evt) { fileBlob = evt.target.result; let data = { Nam..

Frontend/javaScript 2023.04.25

[MariaDB] 환경 구축 (생성, 삭제, 권한, 백업)

1. DATABASE 생성 1-1.Window Menu – MySql Client 진입. 1-2.DB 변경 >> USE MYSQL - MariaDB [(none)] 에서 MariaDB [(mysql)] 로 변경 됩니다. 1-3.DATABASE 생성 >> CREATE DATABASE [DATABASE명]; 1-4.DATABASE 조회 >> SHOW DATABASES - 앞에서 생성한 DATABASE 확인할 수 있습니다. 2. 계정 생성 2-1. 계정 생성 >> CREATE USER ‘[USER_NAME]‘@’[호스트]’ IDENTIFIED BY ‘[PASSWORD]’; - 입력한 USER 명으로 새로운 USER 가 생성됩니다. * 호스트에 ‘%’ 는 모든 이라는 의미이다. 2-2. 사용자 계정 조회 >> ..

SQL/RDBMS 2023.04.25