You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Web-Dev-For-Beginners/translations/ko/quiz-app/README.md

6.5 KiB

퀴즈 앱

이 퀴즈들은 데이터 과학 커리큘럼의 강의 전후 퀴즈로, https://aka.ms/webdev-beginners에서 제공됩니다.

번역된 퀴즈 세트 추가하기

번역된 퀴즈를 추가하려면 assets/translations 폴더에 일치하는 퀴즈 구조를 생성하세요. 원본 퀴즈는 assets/translations/en에 있습니다. 퀴즈는 여러 그룹으로 나뉘어 있으며, 올바른 퀴즈 섹션과 번호를 맞춰야 합니다. 이 커리큘럼에는 총 40개의 퀴즈가 있으며, 번호는 0부터 시작합니다.

번역 파일의 구조는 다음과 같습니다:
[
    {
        "title": "A title",
        "complete": "A complete button title",
        "error": "An error message upon selecting the wrong answer",
        "quizzes": [
            {
                "id": 1,
                "title": "Title",
                "quiz": [
                    {
                        "questionText": "The question asked",
                        "answerOptions": [
                            {
                                "answerText": "Option 1 title",
                                "isCorrect": true
                            },
                            {
                                "answerText": "Option 2 title",
                                "isCorrect": false
                            }
                        ]
                    }
                ]
            }
        ]
    }
]

번역을 완료한 후, en의 규칙을 따라 번역 폴더의 index.js 파일을 편집하여 모든 파일을 가져오도록 수정하세요.

assets/translationsindex.js 파일을 편집하여 새 번역 파일을 가져오도록 설정하세요.

예를 들어, 번역된 JSON 파일이 ex.json이라면, 'ex'를 로컬라이제이션 키로 설정하고 아래와 같이 입력하세요:

index.js
import ex from "./ex.json";

// if 'ex' is localization key then enter it like so in `messages` to expose it 

const messages = {
  ex: ex[0],
};

export default messages;

퀴즈 앱을 로컬에서 실행하기

사전 준비

설치 및 설정

  1. 템플릿에서 리포지토리를 생성하세요.

  2. 새로 생성한 리포지토리를 클론하고, quiz-app 디렉토리로 이동하세요.

    git clone https://github.com/your-github-organization/repo-name
    cd repo-name/quiz-app
    
  3. npm 패키지와 의존성을 설치하세요.

    npm install
    

앱 빌드하기

  1. 솔루션을 빌드하려면 다음 명령을 실행하세요:

    npm run build
    

앱 시작하기

  1. 솔루션을 실행하려면 다음 명령을 실행하세요:

    npm run dev
    

[선택 사항] 린팅

  1. 코드가 린트되었는지 확인하려면 다음 명령을 실행하세요:

    npm run lint
    

퀴즈 앱을 Azure에 배포하기

사전 준비

  • Azure 구독. 무료로 가입하려면 여기를 클릭하세요.

    이 퀴즈 앱을 배포하는 비용 추정: 무료

Azure에 배포하기

위 링크를 통해 Azure에 로그인한 후, 구독과 리소스 그룹을 선택하세요:

  • 정적 웹 앱 세부 정보: 이름을 제공하고 호스팅 플랜을 선택하세요.

  • GitHub 로그인: 배포 소스를 GitHub로 설정한 후 로그인하고 양식의 필수 필드를 채우세요:

    • Organization 조직을 선택하세요.
    • Repository Web Dev for Beginners 커리큘럼 리포지토리를 선택하세요.
    • Branch - 브랜치(main)를 선택하세요.
  • 빌드 프리셋: Azure Static Web Apps는 애플리케이션에서 사용된 프레임워크를 감지하는 알고리즘을 사용합니다.

    • App location - ./quiz-app
    • Api location -
    • Output location - dist
  • 배포: 'Review + Create'를 클릭한 후 'Create'를 클릭하세요.

    배포가 완료되면, 리포지토리의 .github 디렉토리에 워크플로 파일이 생성됩니다. 이 워크플로 파일에는 앱이 Azure에 다시 배포되는 이벤트에 대한 지침이 포함되어 있습니다. 예를 들어, 브랜치 main에서 push가 발생했을 때 등.

    워크플로 파일 예시 GitHub Actions 워크플로 파일의 예시는 다음과 같습니다: name: Azure Static Web Apps CI/CD
    on:
    push:
        branches:
        - main
    pull_request:
        types: [opened, synchronize, reopened, closed]
        branches:
        - main
    
    jobs:
    build_and_deploy_job:
        runs-on: ubuntu-latest
        name: Build and Deploy Job
        steps:
        - uses: actions/checkout@v2
        - name: Build And Deploy
            id: builddeploy
            uses: Azure/static-web-apps-deploy@v1
            with:
            azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN }}
            repo_token: ${{ secrets.GITHUB_TOKEN }}
            action: "upload"
            app_location: "quiz-app" # App source code path
            api_location: ""API source code path optional
            output_location: "dist" #Built app content directory - optional
    
  • 배포 후: 배포가 완료되면 'Go to Deployment'를 클릭한 후 'View app in browser'를 클릭하세요.

GitHub Action(워크플로)이 성공적으로 실행되면, 라이브 페이지를 새로고침하여 애플리케이션을 확인하세요.

면책 조항:
이 문서는 AI 번역 서비스 Co-op Translator를 사용하여 번역되었습니다. 정확성을 위해 최선을 다하고 있지만, 자동 번역에는 오류나 부정확성이 포함될 수 있습니다. 원본 문서의 원어 버전을 권위 있는 출처로 간주해야 합니다. 중요한 정보의 경우, 전문적인 인간 번역을 권장합니다. 이 번역 사용으로 인해 발생하는 오해나 잘못된 해석에 대해 책임을 지지 않습니다.