PGR21.com
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다.
통합 규정을 준수해 주십시오. (2015.12.25.)
Date 2024/06/12 01:03:08
Name Mindow
Subject [질문] 개발자분들~ 간단한 자바스크립트(with제이쿼리) 질문 드려요
저는 스크립트 초보라서 헷갈리지만 개발자 분에겐 쉬운 문제일 것 같습니다.

div 박스 4개가 나란히 있다고 가정하고 css로 각자 높이가 100px, 200px, 300px, 400px로 잡혀있다고 가정했을 때

목표는 스크립트로 박스 4개의 높이 중 가장 높은 것 찾아서 변수로 담아서 콘솔로그 찍기입니다.

제 추측으로는 방향이 일단 각각 박스의 값을 배열로 담아서 배열에 있는 애들끼리 비교해서 높은 값 찾으면 될 것 같은데....

제가 생각한 방향은 맞을까요?


아래는 제가 시도한 스크립트 코드입니다.
제이쿼리 세팅 되어있습니다.

$(".box").each(function(){
                let h = $(this).outerHeight();
                let arr = [h];
                console.log(arr);
            });

이렇게 하니까 하나의 배열이 아닌 length 1인 4개의 배열이 콘솔로그로 찍히더군요

arr 라는 변수의 배열 안에 length 4개로 [100, 200, 300, 400]; 이 찍히게 하고 싶은데 잘 안 됩니다.

요기까지만 하면 Math.max.apply 로 높은 값 찾기는 어렵지 않게 될 것 같은데...

each 로 돌린 값들을 하나의 배열에 담는게 어렵습니다


통합규정 1.3 이용안내 인용

"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.
법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
24/06/12 02:06
수정 아이콘
요런질문은 이 질문 내용 그대로 ChatGPT에 물어보시는게 빠를꺼에요.
24/06/12 10:29
수정 아이콘
와 요즘 챗지피티가 그런 것도 대답해주나보군요 덜덜..
24/06/12 02:44
수정 아이콘
비몽사몽이라 반복문 안에서 굳이 해야 하나 싶긴 한데, 간단히 이런식으로도 구현은 될거에요.
let boxHeights = $(".box").toArray().map(v => $(v).height());
1. boxHeights.sort().reverse()[0];
2. boxHeights.reduce((prev, curr) => prev > curr ? prev : curr);
3. Math.max(...boxHeights);
첫댓 써주신것처럼 우리의 gpt님은 더 자세히 설명을..
24/06/12 10:29
수정 아이콘
답변 감사합니다!!
이동파
24/06/12 08:23
수정 아이콘
Gpt-4o 답변
네, 방향은 맞습니다! `each` 루프 안에서 배열을 선언하게 되면 각 루프마다 새로운 배열이 생성되기 때문에 각각의 높이가 별도의 배열에 들어가게 됩니다. 이를 해결하기 위해 배열을 루프 바깥에서 선언하고, 루프 안에서는 해당 배열에 높이를 추가해주면 됩니다.

다음은 수정된 코드입니다:

```javascript
// 배열을 루프 바깥에서 선언합니다.
let arr = [];

// 각 .box 요소를 순회하며 높이를 배열에 추가합니다.
$(".box").each(function(){
let h = $(this).outerHeight();
arr.push(h); // 배열에 높이를 추가합니다.
});

// 배열을 콘솔에 출력합니다.
console.log(arr);

// 배열에서 가장 높은 값을 찾습니다.
let maxHeight = Math.max.apply(null, arr);

// 가장 높은 값을 콘솔에 출력합니다.
console.log("가장 높은 높이: " + maxHeight + "px");
```

이제 `arr` 배열은 `[100, 200, 300, 400]`처럼 각 박스의 높이를 담게 되고, `Math.max.apply(null, arr)`를 사용하여 가장 높은 값을 찾을 수 있습니다.

위의 코드에서는 `each` 루프 바깥에 `arr` 변수를 선언하고, 각 박스의 높이를 `arr` 배열에 `push` 메서드를 사용하여 추가합니다. 그런 다음, `Math.max.apply(null, arr)`를 사용하여 배열에서 가장 큰 값을 찾습니다.
24/06/12 10:29
수정 아이콘
답변 감사합니다~! 해당 코드 보고 바로 해결했습니다!
상어이빨
24/06/12 08:23
수정 아이콘
arr은 each문 위에 선언하시고
arr.push
24/06/12 10:29
수정 아이콘
감사합니다!
박근혜
24/06/12 13:32
수정 아이콘
chatgpt 가 작성해준 코드입니다.

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Find Max Height</title>
<style>
.box {
width: 100px;
display: inline-block;
}
.box1 { height: 100px; background-color: lightblue; }
.box2 { height: 200px; background-color: lightgreen; }
.box3 { height: 300px; background-color: lightcoral; }
.box4 { height: 400px; background-color: lightgoldenrodyellow; }
</style>
</head>
<body>
<div class="box box1"></div>
<div class="box box2"></div>
<div class="box box3"></div>
<div class="box box4"></div>

<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script>
$(document).ready(function() {
let maxHeight = 0;
$('.box').each(function() {
let height = $(this).height();
if (height > maxHeight) {
maxHeight = height;
}
});
console.log("The highest box height is: " + maxHeight + "px");
});
</script>
</body>
</html>
24/06/14 18:54
수정 아이콘
오 배열에 몰아넣고 비교가 아니라 빈 변수에 할당을 계속줘서 비교하는 방법인가보군요 답변감사합니다 그나저나 챗지피티 신기하긴하네요 크크 10년뒤에는 a4지 몇장 분량으로 설명 쭉 쓰면 사이트 하나 뚝딱되겠어요
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
176996 [질문] 세탁기 건조기 추천 부탁드려요. [8] 율리우스 카이사르3005 24/07/08 3005
176994 [질문] 전기 계량기 읽는 법 아시는 분 계실까요? [2] 개념은?2956 24/07/08 2956
176993 [질문] 실내 자전거 운동 도움이 될까요? [25] 이쥴레이3038 24/07/08 3038
176992 [질문] 조립 pc 사려고 하는데 컴퓨존에서 그냥 추천pc 구입해도되나요? [22] 순무3112 24/07/08 3112
176989 [질문] 나고야로 출장가는데 2~3일 정도 더 다녀올 곳 있을까요? [12] 김유라1929 24/07/08 1929
176988 [질문] 중국팀, 젠지, 티원 관계 질문입니다. [30] 완성형폭풍저그2980 24/07/08 2980
176987 [질문] 일산 회식 메뉴 추천 부탁드립니다 [3] 정 주지 마!1855 24/07/08 1855
176986 [질문] 영상 촬영용 카메라 질문 드립니다! [5] 골드쉽1964 24/07/08 1964
176985 [질문] 입술에 포비딘 발라도 되나요 [4] 앗흥2224 24/07/08 2224
176984 [질문] 안드로이드 다크모드 자동 전환 [2] 아르거스의사도3345 24/07/07 3345
176983 [질문] 한문철 티비 사고시 과속에 대한 귀책률 의문점입니다. [9] 서낙도3141 24/07/07 3141
176982 [질문] 시드니 최근 여행 해보신분 질문드립니다. [4] 하카세2131 24/07/07 2131
176981 [질문] 어제 운전중에 다툼이 있었는데 제가 걱정할 일이 있을까요? [28] 찬양자4410 24/07/07 4410
176980 [질문] 일본여행 숙소 위치 질문입니다 [4] 드문2321 24/07/07 2321
176979 [질문] 윈도우 그림 파일 클릭시 바로 전체화면으로 나오게 하는 방밥 [2] 프라임에듀1552 24/07/07 1552
176978 [질문] 플레이스테이션4 사고 싶은데 가이드 좀 알려주세요~ [23] 서귀포스포츠클럽3233 24/07/07 3233
176977 [질문] 사업장 에어컨 설치에 관해 여쭙습니다. [2] 소월향2147 24/07/07 2147
176976 [질문] 윈도우 11 사용 중에 비정기적으로 명령프롬프트 창이 나타났다가 사라집니다. [3] 고요2896 24/07/07 2896
176975 [질문] 청소하다가 십년 정도 된 술을 찾았는데 음용해도 되려나요 [10] 지구 최후의 밤3687 24/07/06 3687
176974 [질문] 듄1편 재개봉 보려는데, 사전 지식 알아야 할까요? [16] 단다니 쿨쿨2948 24/07/06 2948
176973 [질문] 다이어트 식단 질문입니다 [3] 퍼블레인2838 24/07/06 2838
176972 [질문] 조깅을 시작했어요. 근데 종아리가 아픕니다. [8] 젖병삶는사람3330 24/07/06 3330
176971 [질문] 갤럭시 폰 중 지금 최고 가성비 좋은 거 무엇일까요? [14] 호비브라운3073 24/07/06 3073
목록 이전 다음
댓글

+ : 최근 1시간내에 달린 댓글
+ : 최근 2시간내에 달린 댓글
맨 위로