기본 콘텐츠로 건너뛰기

개발 공부 - Selector(DOM)

용어 뜻:
Selector(선택자)란 말 그대로 선택을 해주는 요소다.
이를 통해 특정 요소들을 선택해서 스타일을 적용할 수 있게 된다.
DOM(Document Object Model) 상에서의 객체를 선택하기 위해서라고도 할 수 있다.
Html은 트리 구조로 이루어져 있는데
html     - head
- body
- tag1
- tag2
이러한 개념적 트리구조를 갖는 문서는 모두 DOM에 해당된다고 생각하면 될 것이다.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
 
1. 기본 셀렉터
 
    1) id 셀렉터
    <tagname id = "abc"></tagname>
    일 때 $("#abc")
 
    2) element 셀렉터
    <tagname> hello </tagname>
    일 때 $("tagname")
    이라고 쓰면 해당 태그에 해당하는 객체 전부를 선택한다.
 
    3) class 셀렉터
    <span class='cssClass'></span>
    <div class='cssClass'></div>
    일 때 $(".casClass")    
    라고 쓰면 지정한 css 클래스를 가진 모든 객체를 가져온다.
 
    4) all 셀렉터
    $("*")
    *은 보통 모든 것을 의미하는데 JQuery에서는 Document를 의미한다.
 
    5) 다중 셀렉터
    $("#abc, tagname, .class")
    셀렉터 표현 안에 여러 표현을 혼합해서 넣는 방법이다. ,로 구분한다.
 
 
2. 상속 셀렉터
 
    1) 자손 셀렉터
    <div id = "girl">
    <p class = 'skirt'> 김소희 </p>
        <div>
            <p> 정준하 </p>
            <span class = 'skirt'> 박소희 </span>
        </div>
    </div> 
    일 때
    $("div.p")                 (1)
    $("#girl.skirt")           (2)
    (1) 표현은 div 밑에 있는 자식 뿐 아니라 해당 div 밑으로 모든 자손들을 포함한다.
    (2) 표현은 id가 girl인 객체 밑의 자손들 중에 class가 skirt인 것을 선택한다.
 
    2) 자녀 셀렉터
    <div id = "girl">
    <p class = 'skirt'> 김소희 </p>
        <div>
            <p> 정준하 </p>
            <span class = 'skirt'> 박소희 </span>
        </div>
    </div> 
    일 때
    $("div > p ")            (1)
    $("#girl > .skirt")        (2)
    (1) 표현은 div 바로 밑의 자식들만 찾아서 p를 선택한다.
    (2) 표현은 id가 girl인 객체 바로 밑에 있는 자식들중 class가 skirt인 것을 선택한다.
 
    3) 바로 밑의 동생 셀렉터
    <span>0</span>
    <div>1</div>
        <p>2</p>
        <p>3</p>
    <div>
          <p>4</p>
    </div>
    <p>5</p>
    일때
    $("div + p")
    이 표현은 div의 바로 밑 동생을 선택하라는 뜻이다.
 
    4) 밑의 동생을 다 선택하는 셀렉터
    $("div ~p")
    이 표현은 div 이후의 동생들 중 p태그를 갖는 동생들을 모두 선택하라는 뜻이다.
 
    
3. 기본 셀렉터 필터
 
    1) :first
        <div>딸기</div>
        <div>사과</div>
        <div class=grape>포도</div>
        <div>바나나</div>
        일 때
        $("div:first")
        는 여러 개의 div 중 첫번째 것만 선택하라는 뜻이다.
        
    2) :last
        $("div:last")
        여러개의 div중 마지막것만 선택하라는 뜻이다.
 
    3) :not(셀렉터)
        $("div:not(.grape)")
        여러개의 div중 css클래스이름이 grape를 빼고 선택하라는 뜻이다.
 
    4) :even 
        $("div:even")
        여러개의 div중 짝수번째 것만 선택하라는 뜻이다.
        이것은 table에서 홀짝수별로 tr색상을 바꿀때 편할 듯 싶다.
 
    5) :odd
        $("div:odd")
        여러개의 div중 홀수번째 것만 선택하라는 뜻이다.
 
    6) :eq(인덱스)
        $("div:eq(2)")
        여러개의 div중 인덱스가 2인 것 즉 3번째 것만 선택하라는 뜻이다.
        첫 번째 인덱스 값이 0부터 시작한다.
    
    7) :gt(인덱스)
        $("div:gt(1)")
        여러개의 div중 인덱스가 1보다 큰 것만 선택하라는 뜻이다.
        gt = greater than
 
    8) :lt(인덱스)
        $("div:lt(2)")
        여러개의 div중 인덱스가 2보다 작은 것만 선택하라는 뜻이다.
        lt = less than
 
    9) :header
        <h1>머리1</h1>
        <h2>머리2</h2>
        $(":header")
        태그중 헤더를 알리는 <h1><h2>, .. 등을 선택하라는 뜻이다.
 
    10) :animated 
        $(":animated")
        이펙트 부분에서 animate로 정의된 것들만 선택하라는 뜻이다.
 
 
4. 내용 셀렉터 필터
    1) :contains(찾는문자열)
        <span>남자의향기</span>
        <span>여자의향기</span>
        <span>남자의땀냄새</span>
        $("span:contains('남자')")              (1)
        $("span:not(:contains('땀'))")       (2)
        (1) span 태그안에 '남자'라는 문자를 가지고 있는 것들을 선택하라는 뜻이다.
        (2) span 태그안에 '땀'라는 문자를 제외한 것들을 선택하라는 뜻이다.
 
    2) ::empty
        <span>남자의향기</span>
        <span>여자의향기</span>
        <span></span>
        $("span:empty")
        span태그 안에 자식이 존재하지 않고 비어 있는 것들을 선택하라는 뜻이다.
 
    3) :has(셀렉터)
        $("div:has(span)")
        자손들중 span을 가지고 있는 div를 선택하라는 뜻이다.     
    
    4) :parent
        $("div:parent")
        자식을 갖고 있거나 태그안이 비어있지 않은 div만을 선택하라는 뜻이다.
 
 
5. hidden/visible 셀렉터 필터
    1) :hidden
        $("span:hidden")           (1)
        $(":hidden","div")       (2)
        css스타일에서 display :none 으로 설정되거나
        폼태그 <input type=hidden ~~/> 인 것들을 선택하라는 뜻이다.
 
        (1) 은 span중에 에서 감추기로 된 것들을 가져오라는 뜻이다.
        (2) 는 div의 자손들중 감추기 속성이 된 것들을 가져오라는 뜻이다.
        주의사항은 visibility:hidden 인 스타일은 선택하지 못한다. ( 최소한 1.3.2버전까지는 )
 
    2) :visible
        $("span:visible")       (1)
        $(":visible","body")       (2)
        화면상에 보이는 객체들을 선택하라는 뜻이다.
        (1) 은 span중에 에서 보이는 것들만 선택하라는 뜻이다.        
        (2) 는 body의 자손들중 보이는 것들을 가져오라는 뜻이다.
        :hidden과 대조적으로 여기에서는 visibility:hidden 인 것은 선택되지 않았다.
cs


출처:
Nextree, 2016-10-28, http://www.nextree.co.kr/p8468/

댓글

이 블로그의 인기 게시물

Ebook - 전자책 drm 상관 없이 pdf로 만들기

yes24와 교보문고에서 ebook을 구매 해야 했는데 너무 불편하고, 필기가 매우 화날 정도로 안 좋아서 원시적으로 사용하기로 했다. 1. 목적 : ebook에서 필기 및 사용이 불편하여 pdf로 변환  2. 용도 : 개인 사용 목적이며 화질이 다소 저하되어도 필기만 용이하면 상관 없음 3. 방법 1) 휴대폰 및 카메라로 동영상을 촬영했다. DRM 때문에 프로그램으로는 촬영이 안 되는 것을 확인했다. 2) 마우스 클릭 해주는 매크로를 사용했다. (1) key_macro.exe > https://blog.daum.net/pg365/250 듀얼 모니터에서 위치 이탈 현상이 있긴 해도 괜찮았다. (2) AutoClick.exe > http://bestsoftwarecenter.blogspot.com/2011/02/autoclick-22.html 이 걸로 잘 사용했다. 3초마다 한 번 클릭하도록 사용했다. 3) 동영상을 이미지로 변경해주는 프로그램을 사용했다. Free Video to JPG Converter > https://free-video-to-jpg-converter.kr.uptodown.com/windows 일 하면서 듀얼 모니터에 켜 놨는데 속도가 괜찮았다. * Every frame 으로 사용해야 한다. 4) 중복 사진 제거해주는 프로그램을 사용했다. VlsiPics  > http://www.visipics.info/index.php?title=Main_Page 생각보다 느리니 퇴근시에 걸어놓고 가면 된다. 한번 play가 끝나면 Auto-select 하고 Delete 하면 된다. 5) 이미지를 일괄 Crop 작업 해주는 프로그램을 사용했다. JPEGCrops > https://jpegcrops.softonic.kr/ * https://joker1209.tistory.com/11 도 참고했다. View -> Large 로 크게 본 뒤, Edit -> Syncronize Crops 로 일괄 동일하게 적용하는 방식을 사

개발 공부 - json JSONObject 사용 시 백슬래시(\), 원화 표시(\) 제거 및 치환

import org.json.simple.JSONObject; String dataString = new String(authData.toJSONString()); dataString = dataString.replaceAll("\\\\", ""); String 으로 안 바뀌는 가 싶어서 String 으로 변환 해 주고 작업 하였다. 사실 toJSONString 해도 정상 동작 해야 하는데 이유를 잘 모르겠음. 그리고 나서 다시 이클립스 구동 하니 toString 도 먹은 걸로 봐서 이상하다고 생각! String dataString = authData.toString(); dataString = dataString.replaceAll("\\\\", ""); 어쨌든 백 슬래시 제거를 해줘야 하는데 \\ 도 아니고 \\\\를 해야 변환이 가능했다는 결말이었습니다. 참고 : https://stackoverflow.com/questions/15450519/why-does-string-replace-not-work/15450539 test =test.replace("KP", "");  replace 후에 담아 주지 않으면 적용이 안 됩니다!

개발 공부 - OracleXETNSListener 서비스가 로컬 컴퓨터에서 시작했다가 중지되었습니다.

여러 가지 요인이 있지만 PC 이름 변경시 OracleXETNSListener 서비스 시작이 불가능합니다. 고치는 법은 C:\oraclexe\app\oracle\product\11.2.0\server\network\ADMIN 와 같은 설치 경로에서 listener.ora와 tnsnames.ora 의 pc명을 바꾼 PC명으로 바꿔주면 됩니다. 그래도 안 된다면 cmd 창에서 services.msc 를 입력 후 OracleXETNSListener 서비스를 시작 시키면 됩니다. 오류명: OracleXETNSListener 서비스가 로컬 컴퓨터에서 시작했다가 중지되었습니다. 일부 서비스는 다른 서비스 또는 프로그램에서 사용되지 않으면 자동으로 중지됩니다. 참고한 사이트들 1. http://blog.naver.com/visioner7/120165951652 2. http://database.sarang.net/?inc=read&aid=6819&criteria=oracle&subcrit=&id=&limit=20&keyword=ora-12560&page=5 이런 걸 보면 오라클은 앙칼진 시골 아가씨야