添加CSS的方式有行内式、嵌入式、外链式、导入式
a)动态引入样式表文件:
复制代码 代码如下:
function loadLink(url){
var link = document.createElement("link");
link.type = "text/css";
link.rel = "stylesheet";
link.href = url;
var head = document.getElmentsByTagName("head")[0];
head.appendChild(link);
}
b)嵌入式:
复制代码 代码如下:
function insertStyles(){
var doc,cssCode=[],cssText;
var len = arguments.length;
var head,style,firstStyle;
if(len == 1){
doc = document;
cssCode.push(arguments[0])
}else if(len == 2){
doc = arguments[0];
cssCode.push(arguments[1]);
}else{
alert("函数最多接收两个参数!");
}
head = doc.getElementsByTagName("head")[0];
styles= head.getElementsByTagName("style");
if(styles.length == 0){
if(doc.createStyleSheet){//ie
doc.createStyleSheet();
}else{//FF
var tempStyle = doc.createElement("style");
tempStyle.setAttibute("type","text/css");
head.appendChild(tempStyle);
}
}
firstStyle = styles[0];
cssText=cssCode.join("\n");
if(!+"\v1"){//opacity兼容
var str = cssText.match(/opacity:(\d?\.\d+);/);
if(str!=null){
cssText = cssText.replace(str[0],"filter:alpha(opacity="+pareFloat(str[1])*100+")");
}
}
if(firstStyle.styleSheet){
firstStyle.styleSheee.cssText += cssText;
}else if(doc.getBoxObjectFor){
firstStyle.innerHTML += cssText;
}else{
firstStyle.appendChild(doc.createTextNode(cssText));
}
}
c)行内式:
复制代码 代码如下:
var addStyle=function (ele,str){
var s = ele.getAttribute("style"),styles;
if(str && typeof str === "string"){
if(!s){
ele.style.cssText = str;
}else{
if(s == '[object]'){//IE6/7 e.getAttribute("style")返回[object]
s=ele.style.cssText;
}
styles= trim(s).split(";");
for (var i=0,len=styles.length; i<len; i++){
var style_i=trim(styles[i]);
var attr=style_i.split(":")[0];
if(str.indexOf(attr)>-1){
styles[i]="";
}else{
styles[i]=style_i;
}
}
ele.style.cssText= styles.join("")+";"+str;
}
}
}
d)导入式:
import "index.css";
操作CSS 类相关的方法:
复制代码 代码如下:
var hasClass=function(ele,value){
var rclass = /[\n\t\r]/g,
value=" "+value+" ";
return (ele.nodeType==1)&&(" "+ele.className+" ").replace(rclass," ").indexOf(value)>-1;
}
var trim=function (val){
return val.replace(/(^\s+)|(\s+$)/g,"");
}
var addClass=function(ele,value){
var rspace = /\s+/,classNames,getClass;
if(value&&typeof value === "string"){
classNames = value.split(rspace);
if(ele.nodeType === 1){
if(!ele.className && classNames.length == 1){
ele.className = value;
}else{
getClass = " "+ele.className+" ";
for(var i=0,len=classNames.length; i<len ;i++){
var cname=classNames[i];
if(!hasClass(ele,cname)){
getClass += cname+" ";
}
}
ele.className = trim(getClass);
}
}
}
}
var removeClass=function(ele,value){
var rclass = /[\n\t\r]/g,classNames,getClass;
if((value&&typeof value === "string")||value === undefined){
classNames = (value||"").split(rspace);
if(ele.nodeType === 1 && ele.className){
if(value){//存在查找要移除的类
getClass = " "+ele.className+" ".replace(rclass," ");//左右空格,为了使类中各类间均等,方便后面替换
for(var i=0,len=classNames.length; i<len; i++){
getClass = getClass.replace(" "+classNames[i]+" "," ")
}
ele.className=trim(getClass);
}else{//不存在移除所有类
ele.className = "";
}
}
}
}
var toggleClass=function(ele,value){
if(typeof value === "string"){
if(hasClass(ele,value)){
removeClass(ele,value);
}else{
addClass(ele,value);
}
}
}
a)动态引入样式表文件:
复制代码 代码如下:
function loadLink(url){
var link = document.createElement("link");
link.type = "text/css";
link.rel = "stylesheet";
link.href = url;
var head = document.getElmentsByTagName("head")[0];
head.appendChild(link);
}
b)嵌入式:
复制代码 代码如下:
function insertStyles(){
var doc,cssCode=[],cssText;
var len = arguments.length;
var head,style,firstStyle;
if(len == 1){
doc = document;
cssCode.push(arguments[0])
}else if(len == 2){
doc = arguments[0];
cssCode.push(arguments[1]);
}else{
alert("函数最多接收两个参数!");
}
head = doc.getElementsByTagName("head")[0];
styles= head.getElementsByTagName("style");
if(styles.length == 0){
if(doc.createStyleSheet){//ie
doc.createStyleSheet();
}else{//FF
var tempStyle = doc.createElement("style");
tempStyle.setAttibute("type","text/css");
head.appendChild(tempStyle);
}
}
firstStyle = styles[0];
cssText=cssCode.join("\n");
if(!+"\v1"){//opacity兼容
var str = cssText.match(/opacity:(\d?\.\d+);/);
if(str!=null){
cssText = cssText.replace(str[0],"filter:alpha(opacity="+pareFloat(str[1])*100+")");
}
}
if(firstStyle.styleSheet){
firstStyle.styleSheee.cssText += cssText;
}else if(doc.getBoxObjectFor){
firstStyle.innerHTML += cssText;
}else{
firstStyle.appendChild(doc.createTextNode(cssText));
}
}
c)行内式:
复制代码 代码如下:
var addStyle=function (ele,str){
var s = ele.getAttribute("style"),styles;
if(str && typeof str === "string"){
if(!s){
ele.style.cssText = str;
}else{
if(s == '[object]'){//IE6/7 e.getAttribute("style")返回[object]
s=ele.style.cssText;
}
styles= trim(s).split(";");
for (var i=0,len=styles.length; i<len; i++){
var style_i=trim(styles[i]);
var attr=style_i.split(":")[0];
if(str.indexOf(attr)>-1){
styles[i]="";
}else{
styles[i]=style_i;
}
}
ele.style.cssText= styles.join("")+";"+str;
}
}
}
d)导入式:
import "index.css";
操作CSS 类相关的方法:
复制代码 代码如下:
var hasClass=function(ele,value){
var rclass = /[\n\t\r]/g,
value=" "+value+" ";
return (ele.nodeType==1)&&(" "+ele.className+" ").replace(rclass," ").indexOf(value)>-1;
}
var trim=function (val){
return val.replace(/(^\s+)|(\s+$)/g,"");
}
var addClass=function(ele,value){
var rspace = /\s+/,classNames,getClass;
if(value&&typeof value === "string"){
classNames = value.split(rspace);
if(ele.nodeType === 1){
if(!ele.className && classNames.length == 1){
ele.className = value;
}else{
getClass = " "+ele.className+" ";
for(var i=0,len=classNames.length; i<len ;i++){
var cname=classNames[i];
if(!hasClass(ele,cname)){
getClass += cname+" ";
}
}
ele.className = trim(getClass);
}
}
}
}
var removeClass=function(ele,value){
var rclass = /[\n\t\r]/g,classNames,getClass;
if((value&&typeof value === "string")||value === undefined){
classNames = (value||"").split(rspace);
if(ele.nodeType === 1 && ele.className){
if(value){//存在查找要移除的类
getClass = " "+ele.className+" ".replace(rclass," ");//左右空格,为了使类中各类间均等,方便后面替换
for(var i=0,len=classNames.length; i<len; i++){
getClass = getClass.replace(" "+classNames[i]+" "," ")
}
ele.className=trim(getClass);
}else{//不存在移除所有类
ele.className = "";
}
}
}
}
var toggleClass=function(ele,value){
if(typeof value === "string"){
if(hasClass(ele,value)){
removeClass(ele,value);
}else{
addClass(ele,value);
}
}
}
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
更新日志
2024年11月29日
2024年11月29日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]