๐Ÿ“š
TIL
  • README
  • Git
    • Basic
    • Remote Repository
    • Log & Diff
    • Rebase&Cherri-Pick
    • git-flow
  • DevOps
    • Monolithic vs MSA
    • Jenkins ์‹œ์ž‘ํ•˜๊ธฐ
    • Airflow ์‹œ์ž‘ํ•˜๊ธฐ
    • Airflow ์‹œ์ž‘ํ•˜๊ธฐ
    • Build Tools
      • maven
  • ๊ฐœ๋ฐœ ๋ฐฉ๋ฒ•๋ก 
    • TDD
  • Spring
    • IoC
    • Is Spring Bean Thread-Safe?
    • Spring Singleton
    • Component Scan
    • Spring Annotation
    • ์˜์กด ๊ด€๊ณ„ ์ฃผ์ž…(DI)
    • Lombok ํ™œ์šฉํ•˜๊ธฐ
    • Bean ์ƒ๋ช…์ฃผ๊ธฐ์™€ ์ฝœ๋ฐฑ
    • Bean Scope
    • AOP(1) - AOP๋ž€
    • AOP(2) - Aop Proxy
    • AOP(3) - Dynamic Proxy
    • AOP(4) - AspectJ
    • POJO
    • Spring ์„œ๋น„์Šค ๊ตฌ์กฐ
    • Transaction
    • JPA๋ž€?
    • JPA Entity
    • Spring Data JPA
    • Spring Data Specification
    • Model Mapping
    • Cache
    • restTemplate
    • YAML ํŒŒ์ผ ์„ค์ •
    • Spring Boot
      • H2 DB ์„ค์ •
      • ๋‹ค์ค‘ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ์„ค์ •
      • Mybatis ์—ฐ๋™ํ•˜๊ธฐ
    • Spring Batch
      • Batch ์‹œ์ž‘ํ•ด๋ณด๊ธฐ
      • Batch Job Flow
      • Job
      • Step
      • Batch Scope & Job Parameter
      • JobRepository์™€ ๋ฉ”ํƒ€ํ…Œ์ด๋ธ”
      • Chunk ์ง€ํ–ฅ ํ”„๋กœ๊ทธ๋ž˜๋ฐ
      • ItemReader
      • ItemProcessor
      • ItemWriter
      • Batch Schedular
      • Job๋ณ„ Bean๋“ฑ๋กํ•˜๊ธฐ
      • Batch ๊ตฌํ˜„์‹œ ๋ฐœ์ƒํ•œ ์˜ค๋ฅ˜ ์ •๋ฆฌ
      • Spring Batch Scaling
        • Multithread Job๊ตฌํ˜„์‹œ ์ด์Šˆ์‚ฌํ•ญ
    • Spring test
      • Junit5
        • ํ…Œ์ŠคํŠธ ์ด๋ฆ„ ํ‘œ๊ธฐ
        • ํ…Œ์ŠคํŠธ ๊ทธ๋ฃน ์‚ฌ์ด์˜ ๊ด€๊ณ„
        • ํƒœ๊ทธ์™€ ํ•„ํ„ฐ๋ง
        • ๋™์  ํ…Œ์ŠคํŠธ
        • ํ…Œ์ŠคํŠธ LifeCycle
        • ํ…Œ์ŠคํŠธ ๋ฉ”์„œ๋“œ
        • ํ…Œ์ŠคํŠธ ์ˆœ์„œ
        • AssertJ
        • ํ…Œ์ŠคํŠธ ๋ณ‘๋ ฌ ์‹คํ–‰
        • AssertJ
        • Mock
      • Spring Boot Test DB ๋ถ„๋ฆฌ
      • Spring Batch Test
  • Web Application
    • Web Server & WAS
    • ๊ด€๋ จ ๊ฐœ๋… - HTTP API, HTML, CSR, SSR
    • Servlet
    • JSP
    • Cookie And Session
    • ์˜ˆ์™ธํŽ˜์ด์ง€
    • Java Bean
    • JDBC
    • Connection Pool
    • ํŒŒ์ผ ์—…๋กœ๋“œ
    • Expression Language
    • JSTL
    • FrontControllerํŒจํ„ด Command ํŒจํ„ด
    • Forwarding
    • MVC
    • ํšŒ์›๊ฐ€์ž…์˜ˆ์ œ
    • ์ฐธ๊ณ 
      • ๊ฐœ๋ฐœํ™˜๊ฒฝ์„ค์ •
  • Java+
    • SOAP/WSDL vs REST
    • WSDL์„ JAVA๋กœ ๋ณ€ํ™˜ํ•˜๊ธฐ
    • SOAP ํ†ต์‹  OPEN API๋กœ ๊ฐœ๋ฐœํ•ด๋ณด๊ธฐ
  • Java
    • Basic
      • ๋ณ€์ˆ˜์™€ ํƒ€์ž…
      • ์—ฐ์‚ฐ์ž
      • ์กฐ๊ฑด๋ฌธ๊ณผ ๋ฐ˜๋ณต๋ฌธ
      • ์ฐธ์กฐ ํƒ€์ž…
      • ํด๋ž˜์Šค
      • ์ƒ์†(Inheritance)
      • ์ธํ„ฐํŽ˜์ด์Šค(Interface)
      • ์ค‘์ฒฉ ํด๋ž˜์Šค์™€ ์ค‘์ฒฉ ์ธํ„ฐํŽ˜์ด์Šค
      • ์˜ˆ์™ธ ์ฒ˜๋ฆฌ
      • API - Object, System, Class, Math, Wrapper
      • API - String, StringBuffer, StringBuilder
      • Thread
      • Generic
      • Lambda
      • Collection - List, Set
      • Collection - Map
      • Collection - Tree
      • Collection - Stack, Queue
      • Stream
      • Reflection
      • ์ •๊ทœํ‘œํ˜„์‹
      • GUI
      • UML
      • Serializable
    • Advanced
      • OutOfMemoryError
      • AutoValue
      • meta-annotation
        • @Retention
        • @Target
        • @Repeatable
    • Effective Java 3/E
      • ITEM 1: Static Factory Method(์ •์  ๋ฉ”์†Œ๋“œ)
      • ITEM 2: Builder Pattern
      • ITEM 3: Singleton
      • ITEM 4: Private Constructor
      • ITEM 5: Dependency Injection
      • ITEM 6: Avoid Unnecessary Object
      • ITEM 7: Eliminate Object Reference
      • ITEM 8: Avoid finalizer and cleaner
      • ITEM 9: try-with-resources
      • ITEM 10: The gerneral contract when overriding equlas
      • ITEM 11: Overriding hashCode
      • ITEM 12: overriding toString
      • ITEM 13: overriding clone judiciously
      • ITEM 14: Consider implementing comparable
      • ITEM 15: ํด๋ž˜์Šค์™€ ๋ฉค๋ฒ„์˜ ์ ‘๊ทผ์„ ์ตœ์†Œํ™”ํ•ด๋ผ
      • ITEM 16: Use Accessor methods
      • ITEM 17: ๋ณ€๊ฒฝ ๊ฐ€๋Šฅ์„ฑ์„ ์ตœ์†Œํ™”ํ•ด๋ผ(๋ถˆ๋ณ€ ํด๋ž˜์Šค)
      • ITEM 18: ์ƒ์†๋ณด๋‹จ ์ปดํฌ์ง€์…˜์„ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 19: ์ƒ์†์„ ๊ณ ๋ คํ•ด ์„ค๊ณ„ํ•˜๊ณ  ๋ฌธ์„œํ™”ํ•ด๋ผ
      • ITEM 20: ์ถ”์ƒ ํด๋ž˜์Šค๋ณด๋‹ค ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์šฐ์„ ํ•˜๋ผ
      • ITEM 21: ์ธํ„ฐํŽ˜์ด์Šค๋Š” ๊ตฌํ˜„ํ•˜๋Š” ์ชฝ์„ ์ƒ๊ฐํ•ด ์„ค๊ณ„ํ•ด๋ผ.
      • ITEM 22: ์ธํ„ฐํŽ˜์ด์Šค๋Š” ํƒ€์ž…์„ ์ •์˜ํ•˜๋Š” ์šฉ๋„๋กœ๋งŒ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 23: ํƒœ๊ทธ ๋‹ฌ๋ฆฐ ํด๋ž˜์Šค๋ณด๋‹ค ํด๋ž˜์Šค ๊ณ„์ธต๊ตฌ์กฐ๋ฅผ ํ™œ์šฉํ•ด๋ผ
      • ITEM 24: ๋ฉค๋ฒ„ ํด๋ž˜์Šค๋Š” ๋˜๋„๋ก static์œผ๋กœ ๊ตฌํ˜„ํ•ด๋ผ
      • ITEM 25: ํ†ฑ๋ ˆ๋ฒจ ํด๋ž˜์Šค๋Š” ํ•œ ํŒŒ์ผ์— ํ•˜๋‚˜๋งŒ ์ƒ์„ฑํ•ด๋ผ.
      • ITEM 26: Raw type์€ ์‚ฌ์šฉํ•˜์ง€ ๋งˆ๋ผ
      • ITEM 27: ๋น„๊ฒ€์‚ฌ ๊ฒฝ๊ณ ๋ฅผ ์ œ๊ฑฐํ•ด๋ผ
      • ITEM 28: ๋ฐฐ์—ด๋ณด๋‹ค๋Š” ๋ฆฌ์ŠคํŠธ๋ฅผ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 29: ์ด์™•์ด๋ฉด ์ œ๋„ค๋ฆญ ํƒ€์ž…์œผ๋กœ ๋งŒ๋“ค์–ด๋ผ
      • ITEM 30: ์ด์™•์ด๋ฉด ์ œ๋„ค๋ฆญ ๋ฉ”์„œ๋“œ๋กœ ๋งŒ๋“ค์–ด๋ผ
      • ITEM 31 : ํ•œ์ •์  ์™€์ผ๋“œ์นด๋“œ๋ฅผ ์‚ฌ์šฉํ•ด API ์œ ์—ฐ์„ฑ์„ ๋†’์—ฌ๋ผ
      • ITEM 32: ์ œ๋„ค๋ฆญ๊ณผ ๊ฐ€๋ณ€์ธ์ˆ˜๋ฅผ ํ•จ๊ป˜ ์“ธ ๋•Œ๋Š” ์‹ ์ค‘ํ•ด๋ผ
      • ITEM 33: ํƒ€์ž… ์•ˆ์ „ ์ด์ข… ์ปจํ…Œ์ด๋„ˆ๋ฅผ ๊ณ ๋ คํ•ด๋ผ
      • ITEM 34: int ์ƒ์ˆ˜ ๋Œ€์‹  ์—ด๊ฑฐ ํƒ€์ž…์„ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 35: ordinal ๋ฉ”์„œ๋“œ ๋Œ€์‹  ์ธ์Šคํ„ด์Šค ํ•„๋“œ๋ฅผ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 36: ๋น„ํŠธ ํ•„๋“œ ๋Œ€์‹  EnumSet์„ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 37: ordinal ์ธ๋ฑ์‹ฑ ๋Œ€์‹  EnumMap์„ ์‚ฌ์šฉํ•ด๋ผ
      • TEM 38 : ํ™•์žฅํ•  ์ˆ˜ ์žˆ๋Š” ์—ด๊ฑฐํƒ€์ž…์ด ํ•„์š”ํ•˜๋ฉด ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 39: ๋ช…๋ช… ํŒจํ„ด๋ณด๋‹ค ์• ๋„ˆํ…Œ์ด์…˜์„ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 40: @Override ์–ด๋…ธํ…Œ์ด์…˜์„ ์ผ๊ด€๋˜๊ฒŒ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 41: ์ •์˜ํ•˜๋ ค๋Š” ๊ฒƒ์ด ํƒ€์ž…์ด๋ผ๋ฉด ๋งˆ์ปค ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 42: ์ต๋ช… ํด๋ž˜์Šค๋ณด๋‹ค๋Š” ๋žŒ๋‹ค๋ฅผ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 43: ๋žŒ๋‹ค๋ณด๋‹ค๋Š” ๋ฉ”์„œ๋“œ ์ฐธ์กฐ๋ฅผ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 44: ํ‘œ์ค€ ํ•จ์ˆ˜ํ˜• ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 45: ์ŠคํŠธ๋ฆผ์€ ์ฃผ์˜ํ•ด์„œ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 46: ์ŠคํŠธ๋ฆผ์—์„œ ๋ถ€์ž‘์šฉ ์—†๋Š” ํ•จ์ˆ˜๋ฅผ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 47: ๋ฐ˜ํ™˜ ํƒ€์ž…์œผ๋กœ๋Š” ์ŠคํŠธ๋ฆผ๋ณด๋‹ค ์ปฌ๋ ‰์…˜์ด ๋‚ซ๋‹ค.
      • ITEM 48: ์ŠคํŠธ๋ฆผ ๋ณ‘๋ ฌํ™”๋Š” ์ฃผ์˜ํ•ด์„œ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 49: ๋งค๊ฐœ๋ณ€์ˆ˜๊ฐ€ ์œ ํšจํ•œ์ง€ ๊ฒ€์‚ฌํ•ด๋ผ
      • ITEM 50: ์ ์‹œ์— ๋ฐฉ์–ด์  ๋ณต์‚ฌ๋ณธ์„ ๋งŒ๋“ค์–ด๋ผ
      • ITEM 51: ๋ฉ”์„œ๋“œ ์‹œ๊ทธ๋‹ˆ์ฒ˜๋ฅผ ์‹ ์ค‘ํžˆ ์„ค๊ณ„ํ•ด๋ผ
      • ITEM 52: ๋‹ค์ค‘์ •์˜๋Š” ์‹ ์ค‘ํžˆ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 53: ๊ฐ€๋ณ€์ธ์ˆ˜๋Š” ์‹ ์ค‘ํžˆ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 54: null์ด ์•„๋‹Œ, ๋นˆ ์ปฌ๋ ‰์…˜์ด๋‚˜ ๋ฐฐ์—ด์„ ๋ฐ˜ํ™˜ํ•ด๋ผ
      • ITEM 55: Optional ๋ฐ˜ํ™˜์€ ์‹ ์ค‘ํ•˜๊ฒŒ ํ•ด๋ผ
      • ITEM 56: ๊ณต๊ฐœ๋œ API ์š”์†Œ์—๋Š” ํ•ญ์ƒ ์ฃผ์„์„ ์ž‘์„ฑํ•ด๋ผ
      • ITEM 57: ์ง€์—ญ๋ณ€์ˆ˜์˜ ๋ฒ”์œ„๋ฅผ ์ตœ์†Œํ™”ํ•ด๋ผ
      • ITEM 58: ์ „ํ†ต์ ์ธ for ๋ฌธ๋ณด๋‹ค๋Š” for-each๋ฌธ์„ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 59: ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ฅผ ์ตํžˆ๊ณ  ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 60: ์ •ํ™•ํ•œ ๋‹ต์ด ํ•„์š”ํ•˜๋‹ค๋ฉด float์™€ double์€ ํ”ผํ•ด๋ผ
      • ITEM 61: ๋ฐ•์‹ฑ๋œ ๊ธฐ๋ณธ ํƒ€์ž…๋ณด๋‹ค๋Š” ๊ธฐ๋ณธ ํƒ€์ž…์„ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 62: ๋‹ค๋ฅธ ํƒ€์ž…์ด ์ ์ ˆํ•˜๋‹ค๋ฉด ๋ฌธ์ž์—ด ์‚ฌ์šฉ์„ ํ”ผํ•ด๋ผ
      • ITEM 63: ๋ฌธ์ž์—ด ์—ฐ๊ฒฐ์€ ๋А๋ฆฌ๋‹ˆ ์ฃผ์˜ํ•ด๋ผ
      • ITEM 64: ๊ฐ์ฒด๋Š” ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์‚ฌ์šฉํ•ด ์ฐธ์กฐํ•ด๋ผ
      • ITEM 65: ๋ฆฌํ”Œ๋ ‰์…˜๋ณด๋‹ค๋Š” ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 66: ๋„ค์ดํ‹ฐ๋ธŒ ๋ฉ”์„œ๋“œ๋Š” ์‹ ์ค‘ํžˆ ์‚ฌ์šฉํ•ด๋ผ
      • ITEM 67: ์ตœ์ ํ™”๋Š” ์‹ ์ค‘ํžˆ ํ•ด๋ผ
      • ITEM 68: ์ผ๋ฐ˜์ ์œผ๋กœ ํ†ต์šฉ๋˜๋Š” ๋ช…๋ช… ๊ทœ์น™์„ ๋”ฐ๋ผ๋ผ
    • ๊ฐ์ฒด์ง€ํ–ฅ ์„ค๊ณ„ ์›์น™(SOLID)
    • ๋””์ž์ธํŒจํ„ด
      • Strategy Pattern
      • Template Method Pattern
      • Factory Method Pattern
      • Singleton
      • Delegation
      • Proxy
      • Adapter Pattern
    • ์‹ค์Šต
      • ์ธํ„ฐํŽ˜์ด์Šค ์‹ค์Šต - Vehicle
      • ์ธํ„ฐํŽ˜์ด์Šค ์‹ค์Šต - Remote
      • GUI ์‹ค์Šต - Calculator
      • GUI ์‹ค์Šต - button
      • GUI ์‹ค์Šต - lotto
      • Thread ์‹ค์Šต - ์ขŒ์„์˜ˆ์•ฝ, ๋ฉ”์„ธ์ง€๋ณด๋‚ด๊ธฐ
    • Jar vs War
  • ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค
    • KEY
    • Index
    • Transaction
    • Trigger
    • Procedure / Function
    • Package
    • ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ๋ฐฐ์›€ํ„ฐ
      • ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ์‹œ์Šคํ…œ
      • ๊ด€๊ณ„๋ฐ์ดํ„ฐ ๋ชจ๋ธ
      • ๊ด€๊ณ„๋Œ€์ˆ˜์™€ SQL
    • MySQL
      • Database๋ž€
      • MySQL ์‹œ์ž‘ํ•˜๊ธฐ
      • MySQL Database
      • MySQL Table
      • CRUD
      • ๊ด€๊ณ„ํ˜• ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค
      • Server์™€ Client
    • PostgreSQL
    • NoSQL
      • Install Cassandra on mac
      • Cassandra๋ž€?
      • NiFi๋ž€
  • Algorithm
    • String
    • Recursion
    • Dynamic Programming
    • Array, Struct, Pointer
    • Math
    • Sort
    • List
    • Stack
    • Queue
    • Graph
    • Tree
    • Maze
    • AVL
    • ์ด์ง„ํƒ์ƒ‰ํŠธ๋ฆฌ(Binary Search Tree)
    • DFS์™€ BFS
    • ๋‹ค์ต์ŠคํŠธ๋ผ ์•Œ๊ณ ๋ฆฌ์ฆ˜(Dijkstra's Algorithm)
    • Red-Black ํŠธ๋ฆฌ
    • A* ์•Œ๊ณ ๋ฆฌ์ฆ˜
    • Heap
    • Huffman Coding
    • Priority Queue
    • Bellman-Ford ์•Œ๊ณ ๋ฆฌ์ฆ˜
    • C++
      • Class
      • STL
        • STL pair
        • STL Container - Associate Container
        • STL Container - Sequence Container
        • STL Container - Container Adapter
  • JavaScript
    • JABASCRIPT BASIC
    • Shallow Copy vs Deep Copy
    • OBJECT MODEL
    • NODE
    • ๋™๊ธฐ ์ฒ˜๋ฆฌ vs ๋น„๋™๊ธฐ ์ฒ˜๋ฆฌ
    • AJAX
    • CALLBACK
    • PROMISE
    • DEFERRER
    • UNDERSCORE
    • WEBPACK
    • SCOPE
    • EXECUTION CONTEXT
    • Image Object
    • BFCache๋ž€?
    • history.scrollRestoration
    • Intersection Observer
    • JWT - JSON Web Token
    • HTML vs JSON
  • Vue.js
    • ํ™˜๊ฒฝ์„ค์ •
    • Vue.js๋ž€?
    • Vue Instance
    • Vue Component
    • Vue Router
    • HTTP ํ†ต์‹ 
    • Template
    • Single File Component
    • Vue Animation
    • Vuex
    • Djnago์™€ ์—ฐ๋™ํ•˜๊ธฐ
  • Backbone.js
    • Model
    • Collection
    • Sync
    • view
  • Node.js
    • Doit! - ๋…ธ๋“œ๋กœ ๋งŒ๋“ค ์ˆ˜ ์žˆ๋Š” ๋Œ€ํ‘œ์ ์ธ ์„œ๋ฒ„์™€ ์šฉ๋„
    • Doit! - ๋…ธ๋“œ์— ๋Œ€ํ•ด ์•Œ์•„๋ณด๊ณ  ๊ฐœ๋ฐœ ๋„๊ตฌ ์„ค์น˜ํ•˜๊ธฐ
    • Doit! - ๋…ธ๋“œ ๊ฐ„๋‹จํ•˜๊ฒŒ ์‚ดํŽด๋ณด๊ธฐ
    • Doit! - ๋…ธ๋“œ์˜ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ์™€ ์นœํ•ด์ง€๊ธฐ
    • Doit! - ๋…ธ๋“œ์˜ ๊ธฐ๋ณธ ๊ธฐ๋Šฅ ์•Œ์•„๋ณด๊ธฐ
    • Doit! - ์›น ์„œ๋ฒ„ ๋งŒ๋“ค๊ธฐ
    • Doit! - ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ์‚ฌ์šฉํ•˜๊ธฐ
    • Doit! - ์ต์Šคํ”„๋ ˆ์Šค ํ”„๋กœ์ ํŠธ๋ฅผ ๋ชจ๋“ˆํ™”ํ•˜๊ธฐ
    • Doit! - ๋ทฐ ํ…œํ”Œ๋ฆฟ ์ ์šฉํ•˜๊ธฐ
    • Doit! - ํŒจ์ŠคํฌํŠธ๋กœ ์‚ฌ์šฉ์ž ์ธ์ฆํ•˜๊ธฐ
    • Doit! - ์ฑ„ํŒ…์„œ๋ฒ„ ๋งŒ๋“ค๊ธฐ
    • Doit! - JSON-RPC ์„œ๋ฒ„ ๋งŒ๋“ค๊ธฐ
  • Python
    • Warning-Could not import the lzma module
    • Pandas
      • Pandas ์ž๋ฃŒ๊ตฌ์กฐ
      • Pandas ๋ฐ์ดํ„ฐ ์ž…์ถœ๋ ฅ
      • DataFrame Data ์‚ดํŽด๋ณด๊ธฐ
      • ์‹œ๊ฐํ™” ๋„๊ตฌ - Matplotlib
  • ML
    • ์ถ”์ฒœ ์‹œ์Šคํ…œ
      • Collaborative Filtering
      • Matrix Factorization
  • Django
    • Basic
      • ํ™˜๊ฒฝ์„ค์ •
      • About Django
      • Start Django Project
      • Secret Key ๊ด€๋ฆฌํ•˜๊ธฐ
      • Settings ๋ถ„๋ฆฌํ•˜๊ธฐ
      • Django App
      • Django View & URL (1)
      • Django Model
        • MySQL ์—ฐ๋™
      • Django Admin
      • Django View & URL (2)
      • Django Template
      • Django Template & View & URL
      • Django Static
      • Django form
    • Advanced
      • Django Generic View
      • Django Automated Testing
      • Django Extenstion Template
      • Django Model Package
      • Django OpenSSL setting
    • REST framework
      • Rest API
      • Serializers
      • ViewSet
    • Error
      • ํ™˜๊ฒฝ์„ค์ • zlib ์˜ค๋ฅ˜๋ฐœ์ƒ
      • ModuleNotFoundError
    • ํŒจํ‚ค์ง€
      • django-debug-toolbar
    • Vue.js ์—ฐ๋™ํ•˜๊ธฐ
  • Ruby
    • variable & input/output
    • ์กฐ๊ฑด๋ฌธ
    • ๋ฐ˜๋ณต๋ฌธ
    • Array & Hash
    • Method
    • Proc&Lamda
    • Class
  • Ruby on Rails
    • Scaffolding
    • Controller
    • Model
    • Model-M:N relation
    • Model Validation
    • ๋ฉ‹์‚ฌ 10์ฃผ์ฐจ ์ˆ˜์—…(Tip)
  • HTML/CSS
    • Udacity - Intro to HTML/CSS
    • Udacity - Responsive Web Design
    • Udacity - Responsive Images
    • HTML Basic
    • CSS Basic
    • HTML5 Sementic Tag
    • HTML ํ…์ŠคํŠธ ๊ด€๋ จ ํƒœ๊ทธ๋“ค
    • HTML5 ๋ฉ€ํ‹ฐ๋ฏธ๋””์–ด
    • HTML ํผ ๊ด€๋ จ ํƒœ๊ทธ๋“ค
    • ํ…์ŠคํŠธ ๊ด€๋ จ ์Šคํƒ€์ผ
    • ์ƒ‰์ƒ๊ณผ ๋ฐฐ๊ฒฝ์„ ์œ„ํ•œ ์Šคํƒ€์ผ
    • ๋ ˆ์ด์•„์›ƒ์„ ์œ„ํ•œ ์Šคํƒ€์ผ
    • CSS ํฌ์ง€์…”๋‹
    • ๋‹ค์žฌ๋‹ค๋Šฅํ•œ CSS3 ์„ ํƒ์ž
    • CSS์™€ ์• ๋‹ˆ๋ฉ”์ด์…˜
    • ๋ฐ˜์‘ํ˜• ์›น์ด๋ž€?
  • OS(์šด์˜์ฒด์ œ)
    • Linux
      • Daemon
      • Cron
      • ํ”„๋กœ์„ธ์Šค ๊ด€๋ จ ๋ช…๋ น์–ด
      • ํ…์ŠคํŠธ ํŒŒ์ผ ๋ช…๋ น์–ด
  • Network
    • ๋„คํŠธ์›Œํฌ ๊ธฐ๋ณธ ๊ฐœ๋…
    • ๋„คํŠธ์›Œํฌ ๊ธฐ๋ณธ ๊ทœ์น™
    • ๋ฌผ๋ฆฌ ๊ณ„์ธต
    • ๋ฐ์ดํ„ฐ ๋งํฌ ๊ณ„์ธต
    • ๋„คํŠธ์›Œํฌ ๊ณ„์ธต
    • ์ „์†ก ๊ณ„์ธต
    • ์‘์šฉ ๊ณ„์ธต
    • ๋„คํŠธ์›Œํฌ ์ „์ฒด ํ๋ฆ„
    • ๋ฌด์„  ๋žœ
  • IT ๊ธฐํƒ€์ง€์‹
    • NAS๋ž€
Powered by GitBook
On this page
  • Ajax
  • XMLHttpRequest ๊ฐ์ฒด
  • JSON
  • JSONP
  • jQuery Ajax
  • Low-Level Interface
  • Shorthand Method
  • ์ฐธ์กฐํŽ˜์ด์ง€

Was this helpful?

  1. JavaScript

AJAX

Previous๋™๊ธฐ ์ฒ˜๋ฆฌ vs ๋น„๋™๊ธฐ ์ฒ˜๋ฆฌNextCALLBACK

Last updated 4 years ago

Was this helpful?

์›น ๋ธŒ๋ผ์šฐ์ €์—์„œ ์›นํŽ˜์ด์ง€๋ฅผ ์š”์ฒญํ•˜๊ฑฐ๋‚˜ ๋งํฌ ํด๋ฆญ์‹œ ํ™”๋ฉด ์ „ํ™˜์ด ๋ฐœ์ƒํ•œ๋‹ค.

์„œ๋ฒ„์™€ ๋ธŒ๋ผ์šฐ์ €์™€์˜ ํ†ต์‹ ์— ์˜ํ•œ ๊ฒƒ์ธ๋ฐ, ์„œ๋ฒ„๋Š” ์š”์ฒญ๋ฐ›์€ ํŽ˜์ด์ง€(HTML)๋ฅผ ๋ฐ˜ํ™˜ํ•œ๋‹ค. ์ด๋•Œ HTML์—์„œ ๋กœ๋“œํ•˜๋Š” CSS, JavaScript ํŒŒ์ผ๋“ค๋„ ๊ฐ™์ด ๋ฐ˜ํ™˜๋œ๋‹ค. ํด๋ผ์ด์–ธํŠธ์˜ ์š”์ฒญ์— ๋”ฐ๋ผ์„œ ์„œ๋ฒ„๋Š” ์ •์ ์ธ ํŒŒ์ผ, ์„œ๋ฒ„ ์‚ฌ์ด๋“œ ํ”„๋กœ๊ทธ๋žจ์ด ๋งŒ๋“œ๋Š” ํŒŒ์ผ, ๋ฐ์ดํ„ฐ๋ฅผ ๋ฐ˜ํ™˜ํ•  ์ˆ˜๋„ ์žˆ๋‹ค. ์„œ๋ฒ„๋กœ ๋ถ€ํ„ฐ ์›นํŽ˜์ด์ง€๊ฐ€ ๋ฐ˜ํ™˜๋˜๋ฉด ํด๋ผ์ด์–ธํŠธ(๋ธŒ๋ผ์šฐ์ €)๋Š” ์ด๋ฅผ ๋ Œ๋”๋งํ•˜์—ฌ ํ™”๋ฉด์— ํ‘œ์‹œํ•œ๋‹ค.

Ajax

Ajax๋Š” Asynchronous JavaScript and XML์˜ ์•ฝ์ž๋กœ JavaScript๋ฅผ ์ด์šฉํ•˜์—ฌ ๋น„๋™๊ธฐ์ (Asynchronous)์œผ๋กœ ์„œ๋ฒ„์™€ ๋ธŒ๋ผ์šฐ์ €๊ฐ„์˜ ๋ฐ์ดํ„ฐ๋ฅผ ๊ตํ™˜ํ•  ์ˆ˜ ์žˆ๋Š” ํ†ต์‹ ๋ฐฉ์‹์ด๋‹ค.

์ฆ‰, ์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ ์›นํŽ˜์ด์ง€๊ฐ€ ๋ฐ˜ํ™˜๋˜๋ฉด ํ•˜๋ฉด ์ „์ฒด๋ฅผ ๊ฐฑ์‹ ํ•˜์ง€ ์•Š๊ณ , ์ผ๋ถ€๋งŒ์„ ๊ฐฑ์‹ ํ•˜๋Š” ๋ฐฉ๋ฒ•์ด๋‹ค.

Ajax์˜ ๋™์ž‘์›๋ฆฌ๋Š” Browser์—์„œ ์„œ๋ฒ„๋กœ ๋ณด๋‚ผ Data๋ฅผ Ajax Engine์„ ํ†ตํ•ด์„œ ์„œ๋ฒ„๋กœ ์ „์†กํ•œ๋‹ค. ์ด๋•Œ Ajax Engine์€ JavaScript๋ฅผ ํ†ตํ•ด DOM์„ ์‚ฌ์šฉํ•˜์—ฌ XMLHttpRequest(XHR) ๊ฐ์ฒด๋กœ ๋ฐ์ดํ„ฐ๋ฅผ ์ „๋‹ฌํ•œ๋‹ค. ์ด XHR์„ ์ด์šฉํ•ด ์„œ๋ฒ„์—์„œ ๋น„๋™๊ธฐ ๋ฐฉ์‹์œผ๋กœ ๋ฐ์ดํ„ฐ๋ฅผ ์กฐํšŒํ•ด ์˜ฌ ์ˆ˜ ์žˆ๋Š” ๊ฒƒ์ด๋‹ค.

์„œ๋ฒ„๋Š” HTML, XML, JSON ๋“ฑ์„ ๋ฐ˜ํ™˜ํ•˜๋Š”๋ฐ Ajax๋ฅผ ์œ„ํ•œ ๋ฐ์ดํ„ฐ ํ˜•์‹์€ JSON์„ ์‚ฌ์šฉํ•˜๋Š” ๊ฒƒ์ด ์ผ๋ฐ˜์ ์ด๋‹ค.

XMLHttpRequest ๊ฐ์ฒด

XMLHttpRequest ๊ฐ์ฒด๋Š” ์›น ๋ธŒ๋ผ์šฐ์ €๊ฐ€ ์„œ๋ฒ„์™€ ๋ฐ์ดํ„ฐ๋ฅผ ๊ตํ™˜ํ•  ๋•Œ ์‚ฌ์šฉํ•œ๋‹ค. ์›น ๋ธŒ๋ผ์šฐ์ €๊ฐ€ ๋ฐฑ๊ทธ๋ผ์šด๋“œ์—์„œ ์„œ๋ฒ„์™€ ๊ณ„์†ํ•ด์„œ ํ†ต์‹ ํ•  ์ˆ˜ ์žˆ๋Š” ๊ฒƒ์€ XMLHttpRequest ๊ฐ์ฒด๋ฅผ ์‚ฌ์šฉํ•˜๊ธฐ ๋•Œ๋ฌธ์ด๋‹ค.

var req = new XMLHttpRequest(); // ๊ฐ์ฒด ์ƒ์„ฑ
req.open('GET','data/test.json',true); // ๋น„๋™๊ธฐ ๋ฐฉ์‹์œผ๋กœ request open, ์„œ๋ฒ„์— ์š”์ฒญ์„ ์ค€๋น„ํ•œ๋‹ค.
req.send(); // request ์ „์†ก, ์ค€๋น„๋œ ์š”์ฒญ์„ ์„œ๋ฒ„์— ์ „๋‹ฌ
  • open() : ์„œ๋ฒ„๋กœ ๋ณด๋‚ผ Ajax ์š”์ฒญ์˜ ํ˜•์‹ ์„ค์ •

    • ์ „๋‹ฌ๋ฐฉ์‹ : ์š”์ฒญ์„ ์ „๋‹ฌํ•  ๋ฐฉ์‹ (GET, POST)

    • URL์ฃผ์†Œ : ์š”์ฒญ์„ ์ฒ˜๋ฆฌํ•  ์„œ๋ฒ„์˜ ํŒŒ์ผ ์ฃผ์†Œ ์ „๋‹ฌ

    • ๋™๊ธฐ์—ฌ๋ถ€ : ์š”์ฒญ์„ ๋™๊ธฐ์‹์œผ๋กœ ์ „๋‹ฌํ• ์ง€ ๋น„๋™๊ธฐ์‹์œผ๋กœ ์ „๋‹ฌํ• ์ง€ ์—ฌ๋ถ€

      • ๋น„๋™๊ธฐ true

      • ๋™๊ธฐ false

open(์ „๋‹ฌ๋ฐฉ์‹, url์ฃผ์†Œ, ๋™๊ธฐ์—ฌ๋ถ€);
  • send() : ์ž‘์„ฑ๋œ Ajax์š”์ฒญ์„ ์„œ๋ฒ„๋กœ ์ „๋‹ฌ

// GET ๋ฐฉ์‹
send(); 
// POST ๋ฐฉ์‹
send(๋ฌธ์ž์—ด);

Ajax์—์„œ๋Š” ์ฃผ๋กœ POST ๋ฐฉ์‹์„ ์‚ฌ์šฉํ•˜์—ฌ ์š”์ฒญ์„ ์ „๋‹ฌํ•œ๋‹ค.

// XMLHttpRequest.readyStaty property ๊ฐ€ ๋ณ€๊ฒฝ๋  ๋•Œ๋งˆ๋‹ค ์ฝœ๋ฐฑํ•จ์ˆ˜(์ด๋ฒคํŠธ ํ•ธ๋“ค๋Ÿฌ) ํ˜ธ์ถœ
req.onreadystatechange = function(e){
  // readyStates๋Š” XMLHttpRequest์˜ ์ƒํƒœ(state)๋ฅผ ๋ฐ˜ํ™˜ํ•œ๋‹ค.
  if(req.readyState===XMLHttpRequest.DONE){
    // status๋Š” response ์ƒํƒœ ์ฝ”๋“œ๋ฅผ ๋ฐ˜ํ™˜ํžŒ๋‹ค.
    if(req.status == 200){
      console.log(req.responseText);
    }else{
      console.log("Error");
    }
  }
}

XMLHttpRequest.send() ๋ฉ”์†Œ๋“œ๋ฅผ ํ†ตํ•ด ์„œ๋ฒ„์— Request๋ฅผ ์ „์†กํ•˜๋ฉด ์„œ๋ฒ„๋Š” Response๋ฅผ ๋ฐ˜ํ™˜ํ•ด ์ฃผ๋Š”๋ฐ ์–ธ์ œ Response๊ฐ€ ํด๋ผ์ด์–ธํŠธ์— ๋„๋‹ฌํ•  ์ง€๋Š” ์•Œ ์ˆ˜ ์—†๋‹ค.

์ด๋•Œ XMLHttpRequest.onreadystatechange ๋Š” Response๊ฐ€ ํด๋ผ์ด์–ธํŠธ์— ๋„๋‹ฌํ•˜์—ฌ ๋ฐœ์ƒ๋œ ์ด๋ฒคํŠธ๋ฅผ ๊ฐ์ง€ํ•˜๊ณ  ์ฝœ๋ฐฑํ•จ์ˆ˜๋ฅผ ์‹คํ–‰ํ•˜์—ฌ ์ค€๋‹ค. ์ฆ‰, req.onreadystatechange๋Š” readyState property๊ฐ€ ๋ณ€๊ฒฝ๋  ๋•Œ๋งˆ๋‹ค ํ˜ธ์ถœ๋˜๋Š” EventHandler์ด๋‹ค.

  • readyState : Request์— ๋ณ€ํ™”๊ฐ€ ๋ฐœ์ƒํ•œ ๊ฒฝ์šฐ์— readyState์˜ property๊ฐ€ ๋ณ€๊ฒฝ๋œ๋‹ค. response๊ฐ€ ํด๋ฆฌ์ด์–ธํŠธ์— ๋„๋‹ฌํ–ˆ๋Š”์ง€๋ฅผ ์ถ”์ ํ•  ์ˆ˜ ์žˆ๋Š” ๊ฐ’์ด๋‹ค.

Value

State

Description

0

UNSENT

XMLHttpRequest.open() ๋ฉ”์†Œ๋“œ ํ˜ธ์ถœ ์ด์ „ XMLHttpRequest ๊ฐ์ฒด๊ฐ€ ์ƒ์„ฑ

1

OPENED

XMLHttpRequest.open() ๋ฉ”์†Œ๋“œ ํ˜ธ์ถœ ์™„๋ฃŒ open() ๋ฉ”์†Œ๋“œ๊ฐ€ ์„ฑ๊ณต์ ์œผ๋กœ ์‹คํ–‰

2

HEADERS_RECEIVED

XMLHttpRequest.send() ๋ฉ”์†Œ๋“œ ํ˜ธ์ถœ ์™„๋ฃŒ ๋ชจ๋“  ์š”์ฒญ์— ๋Œ€ํ•œ ์‘๋‹ต์ด ๋„์ฐฉ

3

LOADING

์„œ๋ฒ„ ์‘๋‹ต ์ค‘(XMLHttpRequest.responseText ๋ฏธ์™„์„ฑ ์ƒํƒœ) ์š”์ฒญํ•œ ๋ฐ์ดํ„ฐ๋ฅผ ์ฒ˜๋ฆฌ ์ค‘์ธ ๊ฒฝ์šฐ

4

DONE

์„œ๋ฒ„ ์‘๋‹ต ์™„๋ฃŒ

  • status : ์„œ๋ฒ„์˜ ๋ฌธ์„œ ์ƒํƒœ๋ฅผ ๋‚˜ํƒ€๋‚ธ๋‹ค.

    • 200 (์ •์ƒ ์‘๋‹ต)

var xhr = new XMLHttpRequest(),
    method = "GET",
    url = "https://dh00023.github.io/";
xhr.open(method, url, true);
xhr.send();

// ajax์š”์ฒญ์„ ์ค‘๋‹จํ•ด์•ผํ•˜๋Š” ๊ฒฝ์šฐ
if (OH_NOES_WE_NEED_TO_CANCEL_RIGHT_NOW_OR_ELSE) {
  xhr.abort();
}
  • abort : ajax์š”์ฒญ์„ ์ทจ์†Œํ•˜๊ฑฐ๋‚˜ ์ค‘๋‹จํ•ด์•ผํ•˜๋Š” ๊ฒฝ์šฐ์— ์‚ฌ์šฉํ•œ๋‹ค.

JSON

JSON(JavaScript Object Notation)์€ JavaScript์˜ ๊ฐ์ฒด ๋ฆฌํ„ฐ๋Ÿด๊ณผ ๋งค์šฐ ํก์‚ฌํ•˜๋‹ค. ํ•˜์ง€๋งŒ JSON์€ ์ˆœ์ˆ˜ํ•œ ํ…์ŠคํŠธ๋กœ ๊ตฌ์„ฑ๋œ ๋ฐ์ดํ„ฐ์ด๋‹ค.

๋ฆฌํ„ฐ๋Ÿด : ์ฝ”๋“œ์ƒ์—์„œ ๋ฐ์ดํ„ฐ๋ฅผ ํ‘œํ˜„ํ•˜๋Š” ๋ฐฉ์‹

// ๊ฐ์ฒด ๋ฆฌํ„ฐ๋Ÿด
var obj = { p1 : 2, p2 : โ€˜2โ€™ };
{
    "key": value
}

ํ‚ค๋Š” ๋ฐ˜๋“œ์‹œ ํฐ๋”ฐ์˜ดํ‘œ("")๋กœ ๋‘˜๋Ÿฌ์‹ธ์•ผํ•œ๋‹ค. (์ž‘์€ ๋”ฐ์˜ดํ‘œ(') ๋ถˆ๊ฐ€)

{
    "name": "jimin",
    "gender": "female",
    "age": 25,
    "alive": true
}

JSON.stringify()

JSON.stringify() ๋ฉ”์†Œ๋“œ๋Š” ๊ฐ์ฒด๋ฅผ JSON ํ˜•์‹์˜ ๋ฌธ์ž์—ด๋กœ ๋ณ€ํ™˜ํ•œ๋‹ค.

var obj = {
    name: "jimin",
    age: 25
};

var strObj = JSON.stringify(obj);
console.log(typeof strObj, strObj);
//=> string {"name":"jimin","age":25}

var arr = [1, 10, "a", false];

var strArray = JSON.stringify(arr);
console.log(typeof strArray, strArray);
//=> string [1,10,"a",false]

JSON.parse()

JSON.parse() ๋Š” JSON ๋ฐ์ดํ„ฐ๋ฅผ ๊ฐ€์ง„ ๋ฌธ์ž์—ด์„ ๊ฐ์ฒด๋กœ ๋ณ€ํ™˜ํ•œ๋‹ค.

์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ ๋ธŒ๋ผ์šฐ์ €๋กœ ์ „์†ก๋œ JSON ๋ฐ์ดํ„ฐ๋Š” ๋ฌธ์ž์—ด์ด๋‹ค. ์ด ๋ฌธ์ž์—ด์„ ๊ฐ์ฒดํ™”ํ•ด์•ผํ•˜๋Š”๋ฐ ์ด๊ฒƒ์„ Deserializing(์—ญ์ง๋ ฌํ™”) ๋ผ ํ•œ๋‹ค. JSON.parse() ๋ฅผ ์‚ฌ์šฉํ•ด ๋ฌธ์ž์—ด์„ ๊ฐ์ฒด๋กœ ๋ณ€ํ™˜ํ•  ์ˆ˜ ์žˆ๋‹ค.

// strObj
//=> string {"name":"jimin","age":25}
var obj = JSON.parse(strObj);

console.log(typeof obj, obj);
//=> object {name: "jimin", age: 25}

JSONP

์š”์ฒญ์— ์˜ํ•ด ์›นํŽ˜์ด์ง€๊ฐ€ ์ „๋‹ฌ๋œ ์„œ๋ฒ„์™€ ๋™์ผํ•œ ๋„๋ฉ”์ธ์˜ ์„œ๋ฒ„๋กœ ์ „๋‹ฌ๋œ ๋ฐ์ดํ„ฐ๋Š” ๋ฌธ์ œ์—†์ด ์ฒ˜๋ฆฌํ•  ์ˆ˜ ์žˆ๋‹ค. ํ•˜์ง€๋งŒ ๋ณด์•ˆ์ƒ์˜ ์ด์œ ๋กœ ๋‹ค๋ฅธ ๋„๋ฉ”์ธ(http, https ํฌํŠธ๊ฐ€ ๋‹ค๋ฅธ ๊ฒฝ์šฐ ํฌํ•จ)์œผ๋กœ๋ถ€ํ„ฐ ์š”์ฒญ(CROSS DOMAIN)์€ ์ œํ•œ๋œ๋‹ค. ์ด๊ฒƒ์„ Same-origin policy ๋™์ผ์ถœ์ฒ˜์›์น™ ์ด๋ผํ•œ๋‹ค.

๋™์ผ์ถœ์ฒ˜์›์น™ ์šฐํšŒํ•˜๋Š” ๋ฐฉ๋ฒ•

  1. Proxy

  2. JSONP : script ํƒœ๊ทธ์˜ ์›๋ณธ ์ฃผ์†Œ์— ๋Œ€ํ•œ ์ œ์•ฝ์ด ์กด์žฌํ•˜์ง€ ์•Š๋Š”๊ฒƒ์„ ์ด์šฉํ•˜์—ฌ ๋‹ค๋ฅธ ๋„๋ฉ”์ธ์˜ ์„œ๋ฒ„์—์„œ ๋ฐ์ดํ„ฐ๋ฅผ ์ˆ˜์ง‘ํ•˜๋Š” ๋ฐฉ๋ฒ•์ด๋‹ค. ์ž์‹ ์˜ ์„œ๋ฒ„์— ํ•จ์ˆ˜๋ฅผ ์ •์˜ํ•˜๊ณ  ๋‹ค๋ฅธ ๋„๋ฉ”์ธ์˜ ์„œ๋ฒ„์— ์–ป๊ณ ์ž ํ•˜๋Š” ๋ฐ์ดํ„ฐ๋ฅผ ์ธ์ˆ˜๋กœ ํ•˜๋Š” ํ•จ์ˆ˜ ํ˜ธ์ถœ๋ฌธ์„ ๋กœ๋“œํ•˜๋Š” ๋ฐฉ๋ฒ•์ด๋‹ค.

  1. Cross-Origin Resource Sharing : HTTP ํ—ค๋”์— ์ถ”๊ฐ€์ ์œผ๋กœ ์ •๋ณด๋ฅผ ์ถ”๊ฐ€ํ•˜์—ฌ ๋ธŒ๋ผ์šฐ์ €์™€ ์„œ๋ฒ„๊ฐ„ ์„œ๋กœ ํ†ต์‹ ํ•ด์•ผํ•œ๋‹ค๋Š” ์‚ฌ์‹ค์„ ์ธ์ง€ํ•˜๋„๋ก ํ•˜๋Š” ๋ฐฉ๋ฒ•์ด๋‹ค.

jQuery Ajax

jQuery๋Š” Ajax ์š”์ฒญ๊ณผ ์‘๋‹ต์„ ์œ„ํ•ด ์œ ์šฉํ•œ ๋ฉ”์†Œ๋“œ๋“ค์„ ์ œ๊ณตํ•ด์ค€๋‹ค.

Low-Level Interface

jQuery.ajax(url[,settings])
//=> jqXHR
jQuery.ajax([settings])
//=> jqXHR

์—ฌ๊ธฐ์„œ [] ๋Š” ๋ฐ˜๋ณตํ•ด์„œ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค๋Š” ์˜๋ฏธ์ด๋‹ค.

settings๋Š” Ajax ์š”์ฒญ ์„ค์ • ์ •๋ณด๋กœ key,value์˜ ์Œ์œผ๋กœ ์ด๋ฃจ์–ด์ง„ ๊ฐ์ฒด์ด๋‹ค.

settings

Description

๋น„๊ณ 

url

์š”์ฒญ์ด ์ „์†ก๋  url

method

http ์š”์ฒญ ๋ฐฉ์‹ (GET/POST)

version added: 1.9.0

type

method์˜ alias (GET/POST)

1.9.0 ์ด์ „ ๋ฒ„์ „์—์„œ ์‚ฌ์šฉ

data

์„œ๋ฒ„๋กœ ์ „๋‹ฌ๋  ๋ฐ์ดํ„ฐ

dataType

์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ ๋ฐ˜ํ™˜๋  ๋ฐ์ดํ„ฐ์˜ type default: Intelligent Guess (xml, json, jsonp, script, html, text)

async

์š”์ฒญ ์‹œ ๋™๊ธฐํ™” ์—ฌ๋ถ€(TRUE/FALSE) ๊ธฐ๋ณธ์€ ๋น„๋™๊ธฐ(asynchronous) ์š”์ฒญ

timeout

์š”์ฒญ ์ œํ•œ ์‹œ๊ฐ„. ์ œํ•œ ์‹œ๊ฐ„ ์•ˆ์— ์š”์ฒญ์ด ์™„๋ฃŒ๋˜์ง€ ์•Š์œผ๋ฉด ์š”์ฒญ์„ ์ทจ์†Œํ•˜๊ฑฐ๋‚˜ error ์ฝœ๋ฐฑ์„ ํ˜ธ์ถœ.

jsonpCallback

JSONP ์š”์ฒญ์„ ์œ„ํ•œ ์ฝœ๋ฐฑ ํ•จ์ˆ˜ ์ด๋ฆ„

success

์š”์ฒญ ์„ฑ๊ณต ์ด๋ฒคํŠธ ํ•ธ๋“ค๋Ÿฌ

error

์š”์ฒญ ์‹คํŒจ ์ด๋ฒคํŠธ ํ•ธ๋“ค๋Ÿฌ

complete

์š”์ฒญ ์™„๋ฃŒ ์ด๋ฒคํŠธ ํ•ธ๋“ค๋Ÿฌ

cache

๋ธŒ๋ผ์šฐ์ €์— ์˜ํ•ด ์š”์ฒญ๋˜๋Š” ํŽ˜์ด์ง€๋ฅผ ์บ์‹œํ•  ์ˆ˜ ์žˆ๋‹ค.(TRUE/FALSE)

beforeSend

http ์š”์ฒญ ์ „์— ๋ฐœ์ƒํ•˜๋Š” ์ด๋ฒคํŠธ ํ•ธ๋“ค๋Ÿฌ

global

์ „์—ญํ•จ์ˆ˜ ํ™œ์„ฑํ™” ์—ฌ๋ถ€ ์„ค์ •

$.ajax({
    url: "data/data.json",
    dataType: "json"
})
.done(function(data){
    // HTTP ์š”์ฒญ์ด ์„ฑ๊ณตํ•˜๋ฉด ๋ฐ์ดํ„ฐ๊ฐ€ done ๋ฉ”์†Œ๋“œ๋กœ ์ „๋‹ฌ
    console.log("success");
})
.fail(function(jqXHR,textStatus,errorThrown){
    // HTTP ์š”์ฒญ์ด ์‹คํŒจํ•˜๋ฉด ์˜ค๋ฅ˜์™€ ์ƒํƒœ ์ •๋ณด๊ฐ€ fail() ๋ฉ”์†Œ๋“œ๋กœ ์ „๋‹ฌ
    console.log("fail: ",jqXHR);
})
.always(function(data,textStatus,jqXHR){
    // HTTP ์š”์ฒญ์˜ ์„ฑ๊ณต, ์‹คํŒจ ์—ฌ๋ถ€์— ์ƒ๊ด€์—†์ด ์–ธ์ œ๋‚˜ alwayw()๋ฉ”์†Œ๋“œ ์‹คํ–‰
    console.log("always: ",data);
});

jqXHR์€ jQuery HTTP Request๋กœ, ๋ธŒ๋ผ์šฐ์ € XMLHttpRequest Object์˜ ์ง‘ํ•ฉ์ด๋‹ค. data์™€ ๊ฑฐ์˜ ๋น„์Šทํ•œ ๊ฐ’์„ ์ง€๋‹ˆ๊ณ  ์žˆ๋Š”๋ฐ ์ถ”๊ฐ€์ ์œผ๋กœ ํ†ต์‹  status ์™€ readyStatus ๋“ฑ์„ ๋ณด๋‚ด์ค€๋‹ค.

Shorthand Method

jQuery.get()

HTTP GET request๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ ๋ฐ์ดํ„ฐ๋ฅผ ๋กœ๋“œํ•œ๋‹ค.

jQuery.get(url, [,data][,success][,dataType])
// returns jqXHR
$.get("data.html",function(data){
    $("#content").html(data);
});

jQuery.getJSON()

HTTP GET request๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ JSON-encoded ๋ฐ์ดํ„ฐ๋ฅผ ๋กœ๋“œํ•œ๋‹ค.

jQuery.getJSON(url[,data][,success])
// returns jqXHR
$.getJSON("data.json",function(data){
    //...
});

jQuery.getScript()

HTTP GET request๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ JavaScript ํŒŒ์ผ์„ ๋กœ๋“œํ•œ ํ›„ ์‹คํ–‰ํ•œ๋‹ค.

jQuery.getScript(url[,success])
// returns jqXHR

jQuery.post()

HTTP GET request๋ฅผ ์‚ฌ์šฉํ•ด ์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ ๋ฐ์ดํ„ฐ๋ฅผ ๋กœ๋“œํ•œ๋‹ค.

jQuery.post(url[,data][,success][,dataType])
// returns jqXHR

.load()

์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ HTML ๋ฐ์ดํ„ฐ๋ฅผ ๋กœ๋“œํ•˜๊ณ  ๋งค์น˜ํ•œ๋‹ค.

.load(url,[,data][,complete])
// returns jQuery
$("#content").load("data.html",function(){
  console.log("Load was performed");
});

์ฐธ์กฐํŽ˜์ด์ง€

์ƒํƒœ ์ฝ”๋“œ ์ฐธ์กฐ
https://joshua1988.github.io/web-development/javascript/promise-for-beginners/
http://tcpschool.com/ajax/ajax_server_request
http://www.nextree.co.kr/p4771/
https://poiemaweb.com/jquery-ajax-json
https://developer.mozilla.org/ko/docs/Web/Guide/AJAX/Getting_Started