天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript 線性漸變二

先來IE的,這是最大的用戶群,如果這部分開發不出來,基本可以說不用做了。IE雖然有Gradient濾鏡,但對比其他瀏覽器的實現特弱,沒有多重漸變(stop-color),不能實現角度漸變,而且還經常失效。我的思路是這樣,假如有一個帶文本的DIV,要實現多重線性漸變,我們首先得把它里面的文本取出來,然后里面放幾個DIV,有幾重就放幾個,然后把它們漸變。如果是垂直漸變,這好辦,什么也不用做,只需設置其濾鏡與各個高就行了。如果水平,就讓其浮動或絕對定位,放到適當的位置,設置其濾鏡與寬。但漸變濾鏡竟然會在浮動后或定位后失效,這是在使用透明濾鏡時聞所未聞的。沒有辦法,祭出上古神器table。但設置長與寬時,使用style來設置是不頂用的,一定要用DOM屬性。漸變則由它的td元素負責。為了去除table元素與td元素之間,td元素與其內容之間的空白,我們還得用到cellPadding與cellSpacing。

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
safari,chrome與opera打算都用SVG實現。為了減少函數的長度,特意搞了兩個輔助函數。
復制代碼 代碼如下:
var createSVG = function(tag){
return document.createElementNS("http://www.w3.org/2000/svg",tag);
};
var attr= function(node,bag){
for(var i in bag){
if(bag.hasOwnProperty(i))
node.setAttribute(i,bag[i])
}
};
var COSgradient = function(entity,stops,width,height,type){
var svg = createSVG("svg");
attr(svg,{width:width+"px",height:height+"px"})
entity.appendChild(svg);
.
var defs = createSVG("defs");
svg.appendChild(defs);
var linearGradient = createSVG("linearGradient");
defs.appendChild(linearGradient);
attr(linearGradient,{id:"nasami",x1:"0%",y1:"0%"})
if(type){
attr(linearGradient,{x2:"100%",y2:"0%"})
}else{
attr(linearGradient,{x2:"0%",y2:"100%"})
}
for(var i=0,j=0,l=stops.length;i<l;i++,j++){
var offset = stops[i].split(",")[0] + "%",
color = stops[i].split(",")[1],
stop = createSVG("stop");
attr(stop,{offset:offset,"stop-color":color});
linearGradient.appendChild(stop);
}
var rect = createSVG("rect");
svg.appendChild(rect);
attr(rect,{x:"0px",y:"0px",width:width+"px",height:height+"px",fill:"url(#nasami)"});
}

firefox則利用其私有屬性:
復制代碼 代碼如下:
var FFgradient= function(entity,stops,width,height,type){
var cssText = ";background: -moz-linear-gradient("
cssText += type? "top,bottom," :"left,right,";
.
for(var i=0,j=0,l=stops.length;i<l;i++,j++){
var offset = stops[i].split(",")[0] + "%",
color = stops[i].split(",")[1];
cssText += "color-stop("+[offset,color]+"),"
}
cssText = cssText.replace(/,$/,"")+") no-repeat;";
entity.style.cssText = cssText+"width:"+width+"px;height:"+height+"px;"
}

不過今天研磨一下,發現firefox還是支持SVG的線性漸變的,因此糾正我原來的觀點。上面的函數只是作用一種實現手段放在這里,它并沒有整合到我最終的版本中(雖然它比SVG實現短很多。)這樣一來,在老一點版本的firefox中我們也能實現線性漸變了。
下面這個運行框里的漸變效果可在所有主流瀏覽器中正常運作。

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
再把它做成類。扼要說明一下:它的第一個參數為IE,第二個為哈希。哈希中的各參數都為必選的,width,height的單位為px;type為0或者1,0代表垂直,1為水平;color-stop代表漸變體,由一個字符串數組構成,每個字符串都是由數字加逗號加顏色值組成,數字表代偏移量,單位為%,顏色值可以是red,green等名詞,也可以是六位或三位的哈希值。漸變體至少要有一個。
復制代碼 代碼如下:
new Gradient("gradient",{width:800,height:100,type:0,"color-stop":["0,red",
3."16,orange","32,yellow","48,green","64,blue","80,indigo","100,violet"]})


[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]

JavaScript技術javascript 線性漸變二,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美午夜精品一区二区蜜桃 | 被同桌摸出水来了好爽的视频 | 黑人巨大两根一起挤进欧美 | 两个吃奶一个添下面视频 | 精品少妇高潮蜜臀涩涩AV | 亚洲精品国产精品精 | 在线播放真实国产乱子伦 | 超碰caopro熟女m超碰分类 | 在线天天看片视频免费观看 | 亚洲中文字幕日本在线观看 | 亚洲欧美日韩高清中文在线 | 高清观看ZSHH96的视频素材 | 色噜噜狠狠一区二区三区 | www.青青草| 98久久人妻少妇激情啪啪 | 国产精品爽爽久久久久久蜜桃 | 果冻传媒2021精品影视 | 一二三四免费中文在线1 | 伦理片在线3348| 丰满的女朋友韩国版在线观看 | 国产精品亚洲AV色欲在线观看 | 微拍秒拍99福利精品小视频 | 无码任你躁久久久久久老妇双奶 | 忘忧草在线 | 色欲无码国产喷水AV精品 | 草莓湿漉漉是好事还是恶性 | 色一伦一情一区二区三区 | 麻豆精品传媒卡一卡二传媒短视频 | 日韩精品人成在线播放 | 国产色无码精品视频国产 | 成人国产精品视频频 | 久久re这里精品23 | 国产精品青青草原app大全 | 97精品在线播放 | 韩国女人高潮嗷嗷叫视频 | 亚洲人成人毛片无遮挡 | 成人在线免费 | 一区二区三区高清视频 | 国产日韩欧美另类 | 露露的性战k8经典 | 90后性爱视频 |