Skip to content

사용자가 만든 JavaScript API를 JavaScript로 파일을 파싱하고 문서로 페이지를 쉽게 생성하는 것을 돕는 애플리케이션

License

Notifications You must be signed in to change notification settings

ohoraming/mkDocumentifyJS

 
 

Repository files navigation

GitHub release (latest by date including pre-releases)

mkDocumentifyJS

목적

사용자가 만든 JavaScript APIJavaScript로 파일을 파싱하고 문서로 페이지를 쉽게 생성하는 것을 도와주기 위함

만든이

@kkn1125 , @ohoraming

알림

명명규칙!

  1. 변수 - 명사
  2. 함수 - 동사

코드 스타일

  1. 상수 - 대문자 (UPPER_CASE)
  2. 변수 - camelCase (lowerCamelCase)

clean-code-javascript-ko 코딩 스타일 협업하기 좋은 코딩 스타일이란? As a JS Developer, This Is What Keeps Me Up at Night [Agile] 애자일 방법론과 스크럼, 스프린트


// package.json

"scripts": {
    "test": "jest --coverage"
},

js 주석을 구문 분석하고 문서화합니다. 현재는 기능만 구현하고 디자인 패턴을 연구하고 있어 깔끔한 코드는 아닙니다.

mkDocumentifyJS는 문서화 된 내용을 보면서 사용자가 쉽게 커스터마이징 가능하도록 하기 때문에 최종 결과물을 검토하고, 문서화 된 내용을 파일로 저장할 수 있도록 하는 것이 목표입니다.

부가 기능은 kimsonohoraming의 재량으로 만들어졌으며, bootstrapfontawesome이 사용되었음을 미리 알려드리며, 다른 사람이 구현한 기능을 사용할 때는 현재 README.md의 하단과 사용된 파일 상단에 개발자의 명칭url을 주석으로 남깁니다.

라이선스MIT라이선스입니다.

어떠한 의견도 환영입니다.

버전

v1.0.0

사용법

문서화 대상 javascript파일을 지정합니다. 그리고 실행하면 문서화된 페이지를 미리 볼 수 있습니다.

이때 Documentify메서드를 초기화 할 때 초기화 옵션에서 문서화 페이지에 대한 정보를 입력하여 커스터마이징이 가능합니다.

<!-- preview.html -->
<!DOCTYPE html>
<html lang="en">
  <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Documentify</title>
    </head>

    <body>
        <script src="documentify.js"></script>
        <script src="index.js"></script>
    </body>
  </body>
</html>

documentify.js를 먼저 연결하고 나서 Documentify.init();로 초기화 해주셔야합니다.

필수 준비사항

dist폴더에 모두 있습니다.

  • documentify.js 연결
  • init 메서드 호출
  • data 폴더 내의 userData.json
  • include 폴더 내의 템플릿 파일들

초기화 옵션

index.js에서 Documentify.init()을 호출 할 때 정해진 초기화 옵션은 아래와 같습니다.

// index.js

// 기본옵션으로 문서화를 진행합니다.
const documentify = Documentify.init();

// 파일 선택을 조정합니다.
const documentify = Documentify.init({
    selectFileMode: false,
    // or
    url: 'dist/assets/js/example.js',
});

// 커스터마이징하여 문서화를 진행합니다.
const documentify = Documentify.init({
    // selectFileMode: true, // 로컬 디렉토리에서 대상파일 찾기 여부
    url: 'dist/assets/js/documentify.js', // 대상 파일 경로
    // datapath: 'dist/data/userData.json', default
    // basepath: 'dist/include/', default
    showOrigin: false, // 원문 코드 보이기 여부
});
구분 옵션명 기능 기본값 단위
1 selectFileMode 문서화 대상 파일을 로컬에서 찾아 선택합니다. false boolean
2 url selectFileModefalse일 때 직접 경로를 입력하여 선택합니다. (Customizing 작업 시 추천합니다.) dist/assets/js/example.js string
3 datapath 문서화에 구현될 정보를 담는 userData.json파일의 경로를 설정합니다. dist/data/userData.json string
4 basepath 문서화에 필요한 html template파일이 존재하는 폴더 경로를 설정합니다. dist/include/ string
5 showOrigin 문서화 시 원문 코드를 보이기 여부를 설정합니다. false boolean

문서화 정보 입력 예제

{
    "page": {
        "version": "v1.0.0",
        "url": "https://kkn1125.github.io",
        "baseurl": "/",
        "name": "DocumentifyJS",
        "descriptions": "개발자 설명",
        "authors": {
            "list": [
                "kimson",
                "ohoraming"
            ],
            "kimson": {
                "name": "kyungnam",
                "avatar": "https://avatars.githubusercontent.com/u/71887242?v=4/",
                "desc": "현재 백앤드 개발자를 준비하고 있는 예비 개발자입니다. 문의사항이나 버그발생은 '문의'라고 입력하셔서 내용을 남겨주시기 바랍니다.",
                "github": "https://github.com/kkn1125/",
                "blog": "https://kkn1125.github.io/"
            },
            "ohoraming": {
                "name": "minji",
                "avatar": "https://avatars.githubusercontent.com/u/77590526?v=4/",
                "desc": "개발자 설명",
                "github": "https://github.com/ohoraming/",
                "blog": "https://ohoraming.github.io/"
            }
        }
    }
}

json을 수정하시면 dist/include/ 의 파일내용을 같이 수정해야합니다.

문서화 정보 입력은 정해진 구조가 없기 때문에 자유롭게 변경하여 사용가능하며, Documentify에서 지원하는 표현식인 {@ ... @}를 사용하여 page정보를 html에서 사용할 수 있으며, d-if, d-for태그를 사용하여 html에서 if문과 for문을 태그로 구현할 수 있습니다.

{@ ... @} 표현식과 d-*태그

<!-- d-*태그 사용 예제 입니다. -->

<d-for var="author" target="page.authors.list">
    <d-if test="${author == 'ohoraming'}">
        <span>나는 ${author}입니다</span>
    </d-if>
</d-for>

<d-for var="i" target="5">
    ${i} 단순히 다섯 번 반복됩니다. var의 i는 0부터 4인 인덱스번호를 사용할 수 있습니다.
</d-for>

<d-for var="test" target="[1,2,3,4,5,'test']">
    ${test} d-for문 내부는 ${...}을 사용해야하며 속성값 외 {@...@}를 사용할 수 있습니다.
</d-for>

<div>
    {@ page.* @} page는 userData.json의 최상위 객체명입니다. json에서 page라는 이름 외 모든 내용을 수정하여 사용할 수 있습니다. <d-if test="3<2">출력되지 않습니다.</d-if>
</div>

{@! page.desc @} "@"뒤에 "!"를 붙이면 주석처리되어 페이지에 표시되지 않습니다.

문서화 페이지 저장

채팅팝업을 통해 저장할 수 있으며, 현재는 단일 페이지로 구성되어 있으며 다음 업데이트에 분할 페이지 저장기능을 추가 할 예정입니다.

저장 후 커스터마이징 가능하도록 assets, html이 따로 분리되어 알집으로 저장됩니다.

기여

관심을 가져주는 것 만으로도 감사할 따름입니다. 현재 두 명 개발 진행 중이며 버그나 에러, 미흡한 부분, 제안 등 모든 의견 주시면 검토하고 반영하도록 하겠습니다.


devkimson Github
ohoraming Github
Sample page
Update List

About

사용자가 만든 JavaScript API를 JavaScript로 파일을 파싱하고 문서로 페이지를 쉽게 생성하는 것을 돕는 애플리케이션

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 98.1%
  • HTML 1.9%