JavaScript动态创建link标签到head里的方法
本文实例讲述了JavaScript动态创建link标签到head里的方法。分享给大家供大家参考。具体分析如下:
相信有很多做前端的朋友碰到过需要用JavaScript动态创建样式表标签——link标签。这里我们就来说说如何在浏览器中动态创建link标签。
使用jQuery创建link标签
如果你开发中喜欢用jQuery,那么用jQuery在创建link标签应该是这样的:
varcssURL='/style.css',
linkTag=$('<linkhref="'+cssURL+'"rel="stylesheet"type="text/css"media="'+(media||"all")+'"charset="'+charset||"utf-8"+'"/>');
//请看清楚,是动态将link标签添加到head里
$($('head')[0]).append(linkTag);使用原生JavaScript创建link标签
如果你喜欢纯天然的JavaScript,就要需要这么写:
varhead=document.getElementsByTagName('head')[0],
cssURL='/style.css',
linkTag=document.createElement('link');
linkTag.id='dynamic-style';
linkTag.href=cssURL;
linkTag.setAttribute('rel','stylesheet');
linkTag.setAttribute('media','all');
linkTag.setAttribute('type','text/css');
head.appendChild(linkTag);IE里特有的方法createStyleSheet
IE里特有的方法createStyleSheet方法也是很方便。
varhead=document.getElementsByTagName('head')[0],
cssURL='themes/BlueNight/style.css',
//document.createStyleSheet的同时就已经把link标签添加到了head中了,怎么讲呢,倒是挺方便
linkTag=document.createStyleSheet(cssURL);createStyleSheet([sURL][,iIndex])方法接受两个参数,sURL就是CSS文件的URL路径。iIndex为可选参数,指插入的link在页面中stylesheetscollection的索引位置,默认是在最后添加新创建的样式。
完整的解决方案
基本上都介绍完了,来看看完整的解决方案吧:
functioncreateLink(cssURL,lnkId,charset,media){
varhead=$($('head')[0]),
linkTag=null;
if(!cssURL){
returnfalse;
}
linkTag=$('<linkhref="'+cssURL+'"rel="stylesheet"type="text/css"media="'+(media||"all")+'"charset="'+charset||"utf-8"+'"/>');
head.append(linkTag);
}
functioncreateLink(cssURL,lnkId,charset,media){
varhead=document.getElementsByTagName('head')[0],
linkTag=null;
if(!cssURL){
returnfalse;
}
linkTag=document.createElement('link');
linkTag.setAttribute('id',(lnkId||'dynamic-style'));
linkTag.setAttribute('rel','stylesheet');
linkTag.setAttribute('charset',(charset||'utf-8'));
linkTag.setAttribute('media',(media||'all'));
linkTag.setAttribute('type','text/css');
linkTag.href=cssURL;
head.appendChild(linkTag);
}
希望本文所述对大家的javascript程序设计有所帮助。