css 의 개념 , overload

over load 는 저그의 오버로더가 아니라는거는..
 
자바쪽 하신분은 그냥 눈요기정도로...
 
css는 cascade style sheet..
 
여기서 중요한게 cascade 라는 단어이고 cascade = overload  라는 개념은 중요합니다..
 
1.css
body{margin:0px}
 
2.css
body{margin:10px}
 
<link rel=..... href="1.css" />
<link rel=..... href="2.css" />
 
이러면 결론은 margin:10px이 적용됩니다.
 
즉 뒤에 나올수록 앞에 나온 내용을 덥어 씌웁니다.
 
1.css
body{margin:0px;padding:10px}
 
2.css
body{margin:10px}
 
<link rel=..... href="1.css" />
<link rel=..... href="2.css" />
 
이러면 결론은 body{margin:10px;padding:10px}
 
겹치는 부분만 변경해서 margin: 에 대해 정의한 부분만 변경되었습니다.
 
 
그렇다면
 
<style>
body{margin:30px}
</style>
<link rel=..... href="1.css" />
<link rel=..... href="2.css" />
 
결론은 body{margin:30px;padding:30px}
 
외부스타일 쉬트 보다는 내부적으로 정의한 <style> 이 더 우선권이 높습니다.
 
즉 <style>에서 정의한 내용이 외부 스타일 쉬트의 정의를 overload 합니다.
 
물론 <body style="margin:30px;padding:30px">  이렇게 정의할 경우 무조건 이 스타일이 적용됩니다.
 
위 내용은 overload 개념이라고 해야 하는게 맞는지 우선순위 라고 해야 맞는지는 정확하지는 않지만, 
 
하여간 동일하게 정의된 스타일을 다른 동일한 정의로 교체 할 수는 있습니다.
 
cascade의 두번째 의미는
 
<table style="text-align:center">
<tr>
<td>aa</td>
</table>
 
했을 경우에 자식태그들도 모두 동일하게 text-align:center 속성을 물려 받게 됩니다.
 
즉 위의 노드의 스타일을 그대로 하위 노드가 물려 받게 됩니다.
 
 
 
자바스크립트도 이러한 오버로딩을 지원합니다.
 
var test = function(){}
var test = function(){}
 
에러가 나지 않고 test라는 함수는 정의되었습니다.
 
var test = function(){alert('1');}
var test = function(a){alert('2')}
var test = function(a,b){alert('3')}
 
이 3개의 함수는 각각 다른 함수이며 js 에러가 발생하지 않습니다.
test();  // 1
test('adfadf') ; // 2
test('adfad', 'adfadfad'); //3
test('adfad', 'adfadf', 'adfad'); // 3
 
overload는 인자의 갯수에 의해서 실행될 함수를 결정짓는 방법이 정확한 의미 일것 같습니다.
 
php 에서는 이러한 오버로딩을 지원하지 않습니다.
 
function a(){}
function a($name){}
 
warning: can't redeclare function a  라는 에러 메시지를 보게 됩니다.
 
이것을 피하기 위하여
function a($name='', $addr='', $age='', $sex=''){};
 
이렇게 독특하다면 독특한 함수를 만들게 되고, 나중에는 저 변수들이 무지하게 헷갈리게 되는 경우가 종종 있습니다.
 
class 도 동일한 이유로 같은 클래스를 정의 할수 없습니다.
 
class a{}
class a{}
 
에러가 납니다.
 
문제는
 
class a{
  function test(){}
}
 
class b extends a{
  function test(){}
}
 
즉 어떠한 경우에도 function test() 가 두번 나와서는 안되고 // abstract나 interface는 예외적으로..
 
5.3버젼 이전에서는  에러가 났었는데,
 
php 5.3 에서는 저러한 경우가 에러가 안나게 됩니다..
 
문득 저렇게 정의 햇는데 에러가 안난다는것을 우연히 알게되서 ( 그전까지는 저렇게 정의 하면 에러가 났던 걸로)
 
함 적어 봤습니다.
 
ps: 스타일 쉬트의 우선순위는
 
inline style : <span style=""> 정의한게 가장 높습니다.
 
내부 스타일 : <style></style> 에서 정의 한게 그 다음
 
외부 스타일 : <link...> 에서 정의한게 그 다음.
 
궁금한건 <style>@import url('');</style> 이경우의 우선순위는 잘 모르겠습니다.
 
span{} : 10점
.blue{} : 100점
span.blue{} : 110점
#blue{} : 1000점
span#blue.blue{} 11100점
td#member.member span#blue.blue{} : 2220점.
 
위와 같이 점수에 의해서 적용될 스타일이 결정지어지게 됩니다.
 
크롬에서 f12 눌러서 보여지는 스타일중에서 --- 이렇게 적용안된다고 표시되어 있는 부분들은 우선권이 낮기 때문에
 
무시되어 졌다는 의미입니다.
 
.. important!    // 이 표시는 중요한것 같은데 아직 의미가 정립안되서 안쓰는 중입니다.
|

댓글 2개

<!doctype html> 에서 head 외에 <style> 은 무시될 수 있습니다.

!important 는 물 흐르듯 내려오는 style 을 무시하고 현재 것을 사용한다라는 의미로
<style>
body{color:red !important;}
body{color:blue}
</style>
이렇게 하면 body 의 색은 기존 처럼 물 흐르듯 위에서 아래로 글자 색이 blue 가 아닌 red 를 먹게 됩니다.
!important 는 잘쓰면 좋지만...
잘못사용하면 완전한 독! 이 됩니다. css 가 꼬일수 있어요...
특히 협업 시 또는 다른사람에게 인수인계 시...
인계받은 사람이 멘붕이 올 수도... ㅎㅎㅎㅎ
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

태그 필터 (최대 3개) 전체 개발자 소스 기타 mysql 팁자료실 javascript php linux flash 정규표현식 jquery node.js mobile 웹서버 os 프로그램 강좌 썸네일 이미지관련 도로명주소 그누보드5 기획자 견적서 계약서 기획서 마케팅 제안서 seo 통계 서식 통계자료 퍼블리셔 html css 반응형 웹접근성 퍼블리싱 표준화 반응형웹 홈페이지기초 부트스트랩 angularjs 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
12년 전 조회 2,078
12년 전 조회 1,580
12년 전 조회 1,615
12년 전 조회 1,360
12년 전 조회 795
12년 전 조회 813
12년 전 조회 2,639
12년 전 조회 837
12년 전 조회 677
12년 전 조회 1,124
12년 전 조회 1,263
12년 전 조회 1,204
12년 전 조회 870
12년 전 조회 2,208
12년 전 조회 2,427
12년 전 조회 1,324
12년 전 조회 892
12년 전 조회 2,537
12년 전 조회 7,791
12년 전 조회 2,244
12년 전 조회 1,015
12년 전 조회 1,384
12년 전 조회 1,131
12년 전 조회 2,347
12년 전 조회 2,034
12년 전 조회 806
12년 전 조회 1,007
12년 전 조회 2,021
12년 전 조회 1,193
12년 전 조회 990
12년 전 조회 656
12년 전 조회 1,311
12년 전 조회 1,042
12년 전 조회 1,958
12년 전 조회 965
12년 전 조회 966
12년 전 조회 1,441
12년 전 조회 855
12년 전 조회 946
12년 전 조회 1,393
12년 전 조회 1,341
12년 전 조회 1,361
12년 전 조회 1,518
12년 전 조회 946
12년 전 조회 1,125
12년 전 조회 1,172
12년 전 조회 773
12년 전 조회 1,194
12년 전 조회 882
12년 전 조회 955
12년 전 조회 618
12년 전 조회 1,351
12년 전 조회 1,648
12년 전 조회 668
12년 전 조회 611
12년 전 조회 1,578
12년 전 조회 657
12년 전 조회 1,245
12년 전 조회 1,045
12년 전 조회 1,472
12년 전 조회 1,558
12년 전 조회 6,249
12년 전 조회 1,564
12년 전 조회 809
12년 전 조회 660
12년 전 조회 687
12년 전 조회 780
12년 전 조회 1,029
12년 전 조회 1,648
12년 전 조회 1,137
12년 전 조회 1,397
12년 전 조회 646
12년 전 조회 745
12년 전 조회 2,734
12년 전 조회 1,834
12년 전 조회 1,559
12년 전 조회 3,386
12년 전 조회 790
12년 전 조회 2,562
12년 전 조회 2,131
12년 전 조회 1,991
12년 전 조회 2,062
12년 전 조회 1,007
12년 전 조회 1,558
12년 전 조회 1,558
12년 전 조회 1,012
12년 전 조회 3,403
12년 전 조회 695
12년 전 조회 1,187
12년 전 조회 1,604
12년 전 조회 2,008
12년 전 조회 867
12년 전 조회 1,572
12년 전 조회 942
12년 전 조회 2,495
12년 전 조회 977
12년 전 조회 679
12년 전 조회 897
12년 전 조회 2,433
12년 전 조회 1,969