用js實(shí)現(xiàn)的抽象CSS圓角效果!!
更新時間:2007年05月03日 00:00:00 作者:
大概是去年的時候吧,就在網(wǎng)上見過了現(xiàn)成的CSS圓角效果的CSS及HTML代碼,例如:
<html>
<head>
<title>css圓角效果</title>
<meta http-equiv="content-type" content="text/html; charset=gb2312">
<style type="text/css">
div.RoundedCorner{background: #9BD1FA}
b.rtop, b.rbottom{display:block;background: #FFF}
b.rtop b, b.rbottom b{display:block;height: 1px;overflow: hidden; background: #9BD1FA}
b.r1{margin: 0 5px}
b.r2{margin: 0 3px}
b.r3{margin: 0 2px}
b.rtop b.r4, b.rbottom b.r4{margin: 0 1px;height: 2px}
</style>
</head>
<body>
<div class="RoundedCorner">
<b class="rtop"><b class="r1"></b><b class="r2"></b><b class="r3"></b><b class="r4"></b></b>
1
<b class="rbottom"><b class="r4"></b><b class="r3"></b><b class="r2"></b><b class="r1"></b></b>
</div>
</body>
</html>
當(dāng)然這樣人為的把圓角值設(shè)置好,也非常好用了,基本上這段代碼拿過去就可以用,但是如果要改變這個圓角的大小,要在這個角上加邊框或基它的效果,那這段代碼拿來就發(fā)揮不了它的威力了.就想做一個抽像化的組件化的東西出來!今年可謂是花費(fèi)了幾乎一天的時間!
想一想,圓角的四個角加在一起正好是一個圓,而圓的表達(dá)式是x*x+y*y=r*r,即x的平方加上y的平方等于半徑的平方!有了這個公式,那么實(shí)現(xiàn)圓解的理論就得以角決了!
開始一步步的測試由沒有到有,由零難化到組件化吧!我把一個圓角實(shí)現(xiàn)分為這樣的結(jié)構(gòu)
[頂部][頂部圓角顯示控制][/頂部]
[主體][主體左邊顯示圓解控制][主體內(nèi)容][主體右邊顯示賀角控制][/主體]
[底部][底部圓解顯示控制][/底部]
得到今天的測試代碼:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>CSS圓角框加組件開發(fā)--測試過程</title>
<style type="text/css">
<!--
#box,#topbox,#bottombox{
width:400px;
}
#box .content{ background-color:#FFCC00;height:400px;}
<?php
for($y=1;$y<=4;$y++){
$x=(int)sqrt(4*4-$y*$y);
$sx=4-$x;
echo ".line{$y}{height:1px;overflow:hidden; background-color:#FFCC00;margin: 0 {$sx}px;}\n";
}
?>
-->
</style>
</head>
<body>
<div id="topbox">
<?php
for($y=4;$y>=1;$y--){
echo "<div class=\"line{$y}\"></div>\n";
}
?>
</div>
<div id="box">
<div class="content"> aaaaaaaaaaaaaaaaaa</div>
</div>
<div id="bottombox">
<?php
for($y=1;$y<=4;$y++){
echo "<div class=\"line{$y}\"></div>\n";
}
?>
</div>
</body>
</html>
<html>
<head>
<title>css圓角效果</title>
<meta http-equiv="content-type" content="text/html; charset=gb2312">
<style type="text/css">
div.RoundedCorner{background: #9BD1FA}
b.rtop, b.rbottom{display:block;background: #FFF}
b.rtop b, b.rbottom b{display:block;height: 1px;overflow: hidden; background: #9BD1FA}
b.r1{margin: 0 5px}
b.r2{margin: 0 3px}
b.r3{margin: 0 2px}
b.rtop b.r4, b.rbottom b.r4{margin: 0 1px;height: 2px}
</style>
</head>
<body>
<div class="RoundedCorner">
<b class="rtop"><b class="r1"></b><b class="r2"></b><b class="r3"></b><b class="r4"></b></b>
1
<b class="rbottom"><b class="r4"></b><b class="r3"></b><b class="r2"></b><b class="r1"></b></b>
</div>
</body>
</html>
當(dāng)然這樣人為的把圓角值設(shè)置好,也非常好用了,基本上這段代碼拿過去就可以用,但是如果要改變這個圓角的大小,要在這個角上加邊框或基它的效果,那這段代碼拿來就發(fā)揮不了它的威力了.就想做一個抽像化的組件化的東西出來!今年可謂是花費(fèi)了幾乎一天的時間!
想一想,圓角的四個角加在一起正好是一個圓,而圓的表達(dá)式是x*x+y*y=r*r,即x的平方加上y的平方等于半徑的平方!有了這個公式,那么實(shí)現(xiàn)圓解的理論就得以角決了!
開始一步步的測試由沒有到有,由零難化到組件化吧!我把一個圓角實(shí)現(xiàn)分為這樣的結(jié)構(gòu)
[頂部][頂部圓角顯示控制][/頂部]
[主體][主體左邊顯示圓解控制][主體內(nèi)容][主體右邊顯示賀角控制][/主體]
[底部][底部圓解顯示控制][/底部]
得到今天的測試代碼:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>CSS圓角框加組件開發(fā)--測試過程</title>
<style type="text/css">
<!--
#box,#topbox,#bottombox{
width:400px;
}
#box .content{ background-color:#FFCC00;height:400px;}
<?php
for($y=1;$y<=4;$y++){
$x=(int)sqrt(4*4-$y*$y);
$sx=4-$x;
echo ".line{$y}{height:1px;overflow:hidden; background-color:#FFCC00;margin: 0 {$sx}px;}\n";
}
?>
-->
</style>
</head>
<body>
<div id="topbox">
<?php
for($y=4;$y>=1;$y--){
echo "<div class=\"line{$y}\"></div>\n";
}
?>
</div>
<div id="box">
<div class="content"> aaaaaaaaaaaaaaaaaa</div>
</div>
<div id="bottombox">
<?php
for($y=1;$y<=4;$y++){
echo "<div class=\"line{$y}\"></div>\n";
}
?>
</div>
</body>
</html>
相關(guān)文章
實(shí)用的JS正則表達(dá)式(手機(jī)號碼/IP正則/郵編正則/電話等)
實(shí)用的JS正則表達(dá)式(手機(jī)號碼/IP正則/郵編正則/電話等),經(jīng)驗(yàn)積累,感興趣的朋友可以了解下,一定會對你有幫助的2013-01-01
Javascript實(shí)現(xiàn)關(guān)聯(lián)數(shù)據(jù)(Linked Data)查詢及注意細(xì)節(jié)
DBpedia對Wikipedia的數(shù)據(jù)變成Linked Data形式,使得機(jī)器也能讀懂并自由獲得這些數(shù)據(jù);本文的主要目的是利用Javascript從DBpedia中獲取我們想要的數(shù)據(jù),感興趣的朋友可以參考下,希望可以幫助到你2013-02-02
javascript筆試題目附答案@20081025_jb51.net
網(wǎng)上找的javascript筆試題目,留檔給自己作參考。2008-10-10
圖片翻轉(zhuǎn)效果具體實(shí)現(xiàn)代碼
想必大家對圖片翻轉(zhuǎn)效果都有所了解吧,其實(shí)很容易實(shí)現(xiàn)的,下面有個不錯的示例,喜歡的朋友可以參考下2014-01-01
js實(shí)現(xiàn)點(diǎn)擊圖片自動提交action的簡單方法
下面小編就為大家?guī)硪黄猨s實(shí)現(xiàn)點(diǎn)擊圖片自動提交action的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10
JavaScript實(shí)現(xiàn)中秋博餅游戲的示例代碼
中秋博餅習(xí)俗源于福建廈門,盛行于漳州的龍海、泉州的安海和金門縣等地。博餅的游戲規(guī)則簡單公平,既充滿競爭懸念,又富于生活情趣,本文將用JavaScript實(shí)現(xiàn)這一經(jīng)典游戲,感興趣的可以了解一下2022-09-09

