찾다
웹 프론트엔드CSS 튜토리얼운전할 수 있나요? 알코올 테스터 코딩

내가 살고 있는 덴마크에서는 안타깝게도 유럽 내에서 기록을 세웠습니다. 우리 아이들은 대륙에서 가장 술을 많이 마시는 사람입니다. 이 때문에 청소년 알코올 소비를 줄이고 어린이들에게 알코올의 영향을 교육하는 데 중점을 두고 있습니다.

저는 학생들에게 알코올이 신체에 어떤 영향을 미치는지, 그리고 혈중 알코올 농도(BAC)가 어떻게 계산되는지 보여주기 위해 HTML과 JavaScript로 우리 지역 학교의 알코올 계산기를 구성했습니다.

BAC는 어떻게 계산되나요?

BAC 또는 "promille"을 추정하려면 몇 가지 주요 정보가 필요합니다.

  • 체중 – 몸이 크면 작은 것보다 알코올이 더 많이 희석될 수 있기 때문입니다.
  • 생물학적 성별 – 체내 수분 함량이 다르기 때문에 체내 알코올 분포에 영향을 줍니다.
  • 마시는 알코올 단위수 – 음료 종류마다 알코올 농도가 다르기 때문입니다.

알코올 단위 계산

음료수에 따라 알코올 양과 알코올 농도에 따라 혈류에 알코올 양이 달라집니다. 이를 표준화하기 위해 알코올 계산 단위는 일반적으로 다음과 같이 수행됩니다.

volume (cl) * alcohol percentage * 0.8 / 120

구조

전체 '앱'은

정리된 필드 세트와 명명된 컨트롤을 사용하면 다음을 통해 필요한 요소를 쉽게 추출할 수 있습니다.
const { add, addbeverage, etc. } = app.elements;

BAC 한도는 지역마다 다르므로 먼저 지역을 선택하고 체중 슬라이더를 조정한 후 생물학적 성별을 선택해야 합니다.

Can I Drive? Coding an Alcohol Tester


다음으로 음료 추가를 시작해 보겠습니다.

Can I Drive? Coding an Alcohol Tester

이것은 음료 선택기에서 선택할 때까지 단위, 양, 알코올 도수에 대한 개별 필드가 비활성화되고 CSS를 통해 숨겨지는 간단한 입니다.

Can I Drive? Coding an Alcohol Tester

이러한 필드의 가시성은 활성화Elements 기능을 통해 제어됩니다.

[percentage, units, volume].forEach(el => el.disabled = !bool);

그런 다음 음료를 추가하면 소비한 음료 목록이 생성되고 BAC, 술에 취하는 데 필요한 예상 시간 등이 계산됩니다.

Can I Drive? Coding an Alcohol Tester

그런 다음 계속해서 더 많은 음료를 추가할 수 있으며 이에 따라 BAC가 업데이트됩니다.

Can I Drive? Coding an Alcohol Tester

미국의 법적 BAC가 스웨덴이나 노르웨이보다 4배 더 높다는 사실을 알고 매우 놀랐습니다!

즉, 스웨덴에서는 미국에서 법적으로 허용되는 음주량에 대해 면허를 상실할 수 있습니다


BAC 계산 분석

BAC의 핵심 계산은calculateAnswer 함수에서 처리됩니다.

volume (cl) * alcohol percentage * 0.8 / 120

분석해 보겠습니다.

  1. 알코올 대사율: 알코올 대사율 = 0.015

    • 이 값은 신체가 시간당 BAC를 감소시키는 평균 비율(약 0.015%)을 나타냅니다.
  2. 현재 BAC 계산: currentBAC = ((total * 10) / ((weight.valueAsNumber * 1000) *parseFloat(bodywater.value))) * 100

    • total * 10: 이는 소비된 총 알코올 단위를 그램으로 변환합니다(1 단위는 순수 알코올의 약 10g과 동일하므로).
    • weight.valueAsNumber * 1000: 계산 목적으로 체중을 킬로그램에서 그램으로 변환합니다.
    • bodywater.value: 생물학적 성별을 기반으로 한 소수 요소로 알코올이 체내에 분포하는 방식에 영향을 미칩니다(예: 남성의 경우 0.58, 여성의 경우 0.49).
    • 결과에 100을 곱하여 BAC를 백분율로 변환합니다.
  3. 술에 취하기까지 걸리는 시간 추정: hourToSober = (currentBAC /alcoholMetabolismRate).toFixed(1);

    • 현재 BAC를 대사율로 나누어 BAC가 0에 도달하는 데 필요한 시간을 추정합니다.
  4. 합법적인 운전 상태 확인: canDrive = currentBAC

    • 현재BAC를 선택한 법적 BAC 한도와 비교합니다. 현재 BAC가 한도 내에 있으면 사용자는 "운전하기에 적합한" 것으로 간주됩니다. 그렇지 않으면 그렇지 않습니다.

calculateAnswer 기능은 이 값을 메시지로 결합하여 현재 BAC, 술에 취하기까지의 시간, 사용자가 운전하기에 적합한지 여부를 표시합니다.


… 이것으로 이 튜토리얼을 마칩니다. 원한다면 CodePen을 자유롭게 실험해 보십시오. 아마도 어린이에게 더 친숙한 UX를 만들 수도 있을 것입니다. 이 도구는 추정치를 제공하며 각 음료를 마신 시간과 같은 요소를 고려하지 않는다는 점을 기억하세요. 그리고 이 방법은 술에 취하지 않은 사람들이 사용할 가능성이 높다는 점을 명심하세요!


데모


DALL·E 표지: 1000x420px까지 자를 수 있는 이미지로 초기 Disney 및 Cupheads와 유사한 만화 스타일로 음주 자동차를 생성합니다.

위 내용은 운전할 수 있나요? 알코올 테스터 코딩의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
CSS 그리드는 무엇입니까?CSS 그리드는 무엇입니까?Apr 30, 2025 pm 03:21 PM

CSS 그리드는 복잡하고 반응이 좋은 웹 레이아웃을 만드는 강력한 도구입니다. 디자인을 단순화하고 접근성을 향상 시키며 이전 방법보다 더 많은 제어를 제공합니다.

CSS Flexbox 란 무엇입니까?CSS Flexbox 란 무엇입니까?Apr 30, 2025 pm 03:20 PM

기사는 반응 형 설계에서 공간의 효율적인 정렬 및 분포를위한 레이아웃 방법 인 CSS Flexbox에 대해 설명합니다. Flexbox 사용을 설명하고 CSS 그리드와 비교하고 브라우저 지원 세부 사항을 설명합니다.

CSS를 사용하여 웹 사이트를 반응하게 만드는 방법은 무엇입니까?CSS를 사용하여 웹 사이트를 반응하게 만드는 방법은 무엇입니까?Apr 30, 2025 pm 03:19 PM

이 기사는 Viewport Meta 태그, 유연한 그리드, 유체 미디어, 미디어 쿼리 및 상대 장치를 포함하여 CSS를 사용하여 반응 형 웹 사이트를 만드는 기술에 대해 설명합니다. 또한 CSS 그리드 및 Flexbox를 함께 사용하여 CSS 프레임 워크를 권장합니다.

CSS 박스 크기 부동산은 무엇을합니까?CSS 박스 크기 부동산은 무엇을합니까?Apr 30, 2025 pm 03:18 PM

이 기사는 요소 치수 계산 방법을 제어하는 ​​CSS 박스 크기 속성에 대해 설명합니다. Content-Box, Border-Box 및 Padding-Box와 같은 값과 레이아웃 설계 및 형태 정렬에 미치는 영향을 설명합니다.

CSS를 사용하여 어떻게 애니메이션 할 수 있습니까?CSS를 사용하여 어떻게 애니메이션 할 수 있습니까?Apr 30, 2025 pm 03:17 PM

기사는 CSS, 주요 특성 및 JavaScript와 결합 된 애니메이션 작성에 대해 논의합니다. 주요 문제는 브라우저 호환성입니다.

CSS를 사용하여 프로젝트에 3D 변환을 추가 할 수 있습니까?CSS를 사용하여 프로젝트에 3D 변환을 추가 할 수 있습니까?Apr 30, 2025 pm 03:16 PM

기사는 3D 변환, 주요 속성, 브라우저 호환성 및 웹 프로젝트에 대한 성능 고려 사항에 대한 CSS 사용에 대해 논의합니다. (문자 수 : 159)

CSS에 기울기를 추가 할 수있는 방법은 무엇입니까?CSS에 기울기를 추가 할 수있는 방법은 무엇입니까?Apr 30, 2025 pm 03:15 PM

이 기사는 CSS 그라디언트 (선형, 방사형, 반복)를 사용하여 웹 사이트 비주얼을 향상시키고 깊이, 초점 및 현대적인 미학을 추가합니다.

CSS의 의사 요소는 무엇입니까?CSS의 의사 요소는 무엇입니까?Apr 30, 2025 pm 03:14 PM

기사는 CSS의 의사 요소, HTML 스타일을 향상시키는 데 사용 및 의사 급의 차이점에 대해 설명합니다. 실제 사례를 제공합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.