現在實作圓角普遍用圖片來控制,這種方法有其優點(產生的圓角平滑)。 但同時他也要求有吻合的圖片,如果要動態的改變p的樣式顏色則有些力不從心。還有就是用js來實作。
實作後的呼叫程式碼如下
var objp = getRoundp.call(document,"solid 1px yellow","#dddddd") objp.p.style.width="100px"; objp.Content.style.margin="6 6 6 6 " objp.Content.innerText="这是一个圆角p测试" document.body.appendChild(objp.p);
這樣就產生了一個圓角p
實作原理:原理其實很簡單,在p的top和bottom 加上三條線,用這三條線的不同長度來產生圓角的效果。
實作過程: 如何實現這三條線呢。 用a4b561c25d9afb9ac8dc4d70affff419 這個元素,將其高度 設定為1px 。如果要顯示邊框則為其新增左邊框和右邊框。加入好線條以後,將內容p 和這三條線放在一個容器裡,這個容器也是p。最後回傳一個p類,這個類放兩個屬性,一個是容器p,透過這個容器p可以控制圖形出現的位置和大小高度等屬性。另一個屬性是內容p,透過這個p可以設定這個p的內容,margin,字體顏色,背景顏色,字體大小,等屬性。
注意的問題: 呼叫 getRoundp 這個方法需要傳遞一個方法上下文。我的理解是方法上下文相當與一個指針,指向呼叫方法的物件。為什麼要用這個方法上下文呢? 例如要在ie的 creatPopup 方法 產生出來的popup文檔內新建一個圓角p的話,由於popup只能載入他自己建立的控件,所以可以將popup物件傳遞到方法內部,成為方法上下文指向的物件。 傳遞上下文的方法有兩種function.call(obj,"arg1","arg2") 類似與此。 另一種是 function.apply(obj,arguments)
詳細程式碼如下:
/**************************************************************************/ /*Roundp.js 产生一个圆角p 调用前需设置函数上下文(上下文是指,要创建p的窗口) 例如 var objp = getRoundp.call(document,"","#dddddd") 函数参数argBorderStyle: 边框样式,字符串 例如 "1px solid black" 函数参数argBgColor: 背景颜色,字符串 例如 "#ffffff" 现在只支持边框为1像素 如果超过1像素产生的图形会比较奇怪 如果不设置边框 则没有边框 可以正常使用 本函数返回的是一个Roundp自定义类 如果要设置p的内容请用 obj.Content.innerHtml 或 obj.Content.innerText设置 如果要设置p的高度请用 obj.p.style.width obj.p.style.height设置 */ /**************************************************************************/ /**************************************************************************/ //取得一个圆角p function getRoundp(argBorderStyle,argBgColor){ //创建元素 var pPane =this.createElement("p") var pContent =this.createElement("p") var pContentMax =this.createElement("p") var bTop =this.createElement("b") var bBottom =this.createElement("b") var bTop1 =this.createElement("b") var bTop2 =this.createElement("b") var bTop3 =this.createElement("b") var bTop4 =this.createElement("b") var bBottom1 =this.createElement("b") var bBottom2 =this.createElement("b") var bBottom3 =this.createElement("b") var bBottom4 =this.createElement("b") //背景设置 pPane.style.backgroundColor=argBgColor; pContent.style.backgroundColor=argBgColor; pContentMax.style.backgroundColor=argBgColor; bTop1.style.backgroundColor=argBgColor; bTop2.style.backgroundColor=argBgColor; bTop3.style.backgroundColor=argBgColor; bTop4.style.backgroundColor=argBgColor; bBottom1.style.backgroundColor=argBgColor; bBottom2.style.backgroundColor=argBgColor; bBottom3.style.backgroundColor=argBgColor; bBottom4.style.backgroundColor=argBgColor; bTop.style.backgroundColor="#ffffff"; bBottom.style.backgroundColor="#ffffff"; //样式设置 bTop.style.overflow="hidden"; bBottom.style.overflow="hidden"; bTop1.style.overflow="hidden"; bTop2.style.overflow="hidden"; bTop3.style.overflow="hidden"; bTop4.style.overflow="hidden"; bBottom1.style.overflow="hidden"; bBottom2.style.overflow="hidden"; bBottom3.style.overflow="hidden"; bBottom4.style.overflow="hidden"; bTop.style.display="block"; bBottom.style.display="block"; bTop1.style.display="block"; bTop2.style.display="block"; bTop3.style.display="block"; bTop4.style.display="block"; bBottom1.style.display="block"; bBottom2.style.display="block"; bBottom3.style.display="block"; bBottom4.style.display="block"; //高度设置 pContent.style.height="100%"; pContentMax.style.height="100%"; bTop1.style.height="1px"; bTop2.style.height="1px"; bTop3.style.height="1px"; bTop4.style.height="2px"; bBottom1.style.height="1px"; bBottom2.style.height="1px"; bBottom3.style.height="1px"; bBottom4.style.height="2px"; //边框设置 pContentMax.style.borderLeft=argBorderStyle pContentMax.style.borderRight=argBorderStyle bTop1.style.borderLeft=argBorderStyle; bTop1.style.borderRight=argBorderStyle; bTop1.style.borderTop=argBorderStyle; bTop2.style.borderLeft=argBorderStyle; bTop2.style.borderRight=argBorderStyle; bTop3.style.borderLeft=argBorderStyle; bTop3.style.borderRight=argBorderStyle; bTop4.style.borderRight=argBorderStyle; bTop4.style.borderLeft=argBorderStyle; bBottom1.style.borderLeft=argBorderStyle; bBottom1.style.borderRight=argBorderStyle; bBottom1.style.borderTop=argBorderStyle; bBottom2.style.borderLeft=argBorderStyle; bBottom2.style.borderRight=argBorderStyle; bBottom3.style.borderLeft=argBorderStyle; bBottom3.style.borderRight=argBorderStyle; bBottom4.style.borderLeft=argBorderStyle; bBottom4.style.borderRight=argBorderStyle; //空白间距设置 bTop1.style.margin="0 4px 0 4px" bTop2.style.margin="0 3px 0 3px" bTop3.style.margin="0 2px 0 2px" bTop4.style.margin="0 1px 0 1px" bBottom1.style.margin="0 4px 0 4px" bBottom2.style.margin="0 3px 0 3px" bBottom3.style.margin="0 2px 0 2px" bBottom4.style.margin="0 1px 0 1px" //控件拼装 bTop.appendChild(bTop1); bTop.appendChild(bTop1); bTop.appendChild(bTop2); bTop.appendChild(bTop3); bTop.appendChild(bTop4); bBottom.appendChild(bBottom4); bBottom.appendChild(bBottom3); bBottom.appendChild(bBottom2); bBottom.appendChild(bBottom1); pContentMax.appendChild(pContent) pPane.appendChild(bTop) pPane.appendChild(pContentMax) pPane.appendChild(bBottom) var objRoundp = new Roundp(); objRoundp.p=pPane; objRoundp.Content=pContent; return objRoundp; } /**************************************************************************/ /**************************************************************************/ //自定义类(用来装载p对应内容) function Roundp(){ this.content=0;//p内容 this.p=0;//p容器 } /**************************************************************************/
以上是Javascript圓角div的實作原理與流程程式碼詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!